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Functional Characteristics 


This publication contains detailed information on the 
organization, characteristics, features, and functions 
unique to the IBM System/360 Model 67 Time Sharing 
System. Major areas described include time-sharing 
philosophy, system structure, new units, generalized 
information flow, standard and special features, in- 
struction timings, and the system control panel. 
Descriptions of specific input/output devices used 
with the Model 67 appear in separate publications. See 
the IBM System/360 Bibliography, Form A22-6822 for 
a listing and a brief description of these publications. 
The material in this publication is presented with the 
assumption that the reader has knowledge of System/360 


as defined in the IBM System/360 Principles of Operation, 
Form A22-6821 and the IBM System/360 System Summary, 
Form A22-6810. The IBM System/360 Model 67 Config- 


urator, Form A27-2713 also may be of interest to the 
reader, 
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System/360 Model 67-2 Duplex Configuration 


IBM System/360 is a versatile, all-purpose family of 
data processing equipment that can accommodate the 
wide range of applications which may be encountered 
in a diversified computing activity. The system is 
unique in its capability to grow easily with the needs 
for increased computational capabilities. If particular 
input/output (I/O) equipment is outgrown, more and/or 
faster I/O equipment can be added. Also, processor 
storage capacity can be increased easily. The impor- 
tant point, however, is that any or all of this growth 
can be accomplished without changes, either in system 
programming or in problem programming. 

The basic architecture of System/360 makes it 
ideally suited to operate in a multiprogramming and 
multiprocessing environment, Model 67 extends this 
basic architecture to provide the additional capabilities 
of a time-sharing system. 

Four new units are introduced by the Model 67: 
The IBM 2067 Processing Unit Models 1 and 2, 
The IBM 2365 Processor Storage Model 12 

The IBM 2846 Channel Controller, and 

The IBM 2167 Configuration Unit. 

These new units, together with the IBM 2365 
Processor Storage Model 2, 2860 Selector Channel, 
2870 Multiplexer Channel, and the wide range of IBM 
System/360 control units and devices are the building 
blocks for Model 67 configurations. 

There are two models of the Model 67, termed 
67-1 and 67-2. The Model 67-1 is a single-processor 
(simplex) system which uses the 2067-1 (Figure 1), 
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Figure 1. Model 67-1 Configuration 
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while the Model 67-2 describes systems using the 
2067-2 both in half-duplex (one processor) and in 
duplex (two processor) configurations (Figure 2). The 
Model 67-1 cannot be converted to a Model 67-2 in 

the field. 

The outline configurations of the Model 67 produced 
by the various combinations of a 2365 Processor Stor- 
age and 2067 central processing units (CPU's) shown 
in Figure 3 are only a few of the combinations possible. 

The system control panel is located at one end of 
the 2067. An IBM 1052 Printer-Keyboard can be placed 
adjacent to the 2067 Processing Unit reading board. 

Standard features for any System/360 Model 67 
include: 

Universal Instruction Set 

High-Resolution Interval Timer 

7-Bit Storage Protection 

24-Bit Dynamic Address Translation 
Optional features for System/360 Model 67 include: 

Extended Dynamic Address Translation 

709/7040/7044/7090/7094/7094II Compatibility 

1052 Adapter 

Floating Storage Addressing (2067-1 only) 

Direct Control (2067-1 only) 

Extended Direct Control (2067-2 only) 

Partitioning Sensing (2067-2 only) 

Additional 2846 Attachment (2067-2 only) 

Additional Addressing (2067-2 only) 
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Figure 2. Model 67-2 Configuration 
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Figure 3. Model 67 Outline Configurations 


A variety of control units and I/O devices are available 
for use with the Model 67. Descriptions of specific 
I/O devices appear in separate publications. Config- 
urators for the I/O devices and systems components 
are also available. See IBM System/360 Bibliography, 
Form A22-6822. 

Model 67 is a general-purpose computing system 
which provides the user of an I/O device, called a 
"terminal", with the use of the system at times and 
places of his choosing. 

A general-purpose computing system is one which 
will accommodate a variety of problems, expressed in 
several languages (including the language of the com- 
puter itself), and introduced from different sources. 

Model 67 provides: 


e On-Line Capability -- The Model 67 couples 
users of computation facilities more closely to 
computer systems. This close user-system 
contact does not require physical proximity of 
the terminals; communication lines, dial con- 
nections, or similar apparatus of communications 


technology can be used in the system to convey 
computational power over any distance. The on- 
line capability makes possible the functions of con- 
sole type debugging techniques, conversational 
mode of operation, and the immediate utilization 
of many short duration "shots" on the facility 
without significant delay. To enhance this on-line 
capability, the system employs large-capacity, 
direct-access storage devices to provide access 
both to the data bases and to programs of interest 
to the users. 


e Multiple-Access Capability -- Many users share 
the total system facility concurrently. One 
reason for providing multiple access in on-line 
systems is that, typically, one user does not 
continually require the total system facility. 
Without the multiple-access capability, a brief 
pause by a user would idle the entire system. 
With the multiple-access capability, pauses 
serve other uses. Since the cost of doing this is 
small compared to the facility time recovered, it 
is profitable, therefore, to have the capability of 
serving many users simultaneously. 


e Multiprocessor Capability -- For multiprocessor 
configurations, parallel operation is the normal 
mode of the system. During parallel processor 
operations, two CPU's can execute the same 
monitor simultaneously, independently executing 
programs, accessing storage, and controlling 
input/output. Since the monitor program is not 
changed by execution, simultaneous usage presents 
no problems. 


e Time-Slicing Capability -- Many different tasks 
are interleaved by using a timing mechanism to 
signal the end of the time interval given to one 
task and to permit the transfer of a CPU to another 
task. Each user receives a slice of computer 
time periodically, and within a short cycle of time 
all users are responded to in Some sense. 


Time sharing is characterized by the time-slicing 
capability. Time slicing, in conjunction with the super- 
visor program scheduling and dispatching routines, 
enhances the Model 67s ability to operate as a conven- 
tional batch processing system and as a conversational 
mode processor. 


PROGRAM CHARACTERISTICS 


Several highlights of Time Sharing System/360 
(TSS/360) are described in the following paragraphs; 
TSS /360 is described in greater detail in the IBM 


System/360 Time Sharing System Concepts and Facil- 
ities, Form C28-2003. 


Re-entrant Code 


Much of the coding in the time-sharing system is re- 
entrant. Since a re-entrant program is not modified 
in any way by execution, it can be shared by several 
other programs that can be executed by one or more 
processors. All parameters, data locations, and 
working storage spaces are passed to the re-entrant 
program. The integrity of each user's data is main- 
tained regardless of the number of users who have 
entered the program. 

Re-entrant coding of programs enhances system 
efficiency because only one copy of a multiple-usage 
program or subroutine need be present in processor 
storage. 


Data Set Management 


To the user, the computing system can be a file space 
as well as a computing device. The user need not keep 
programs (problem statements) or data files at his 
location. These can be introduced into the system, 
left in, and recalled and manipulated at will. 

To maintain large sets of files with complete 
safety and security, the system contains a catalog of 
all data files within its storage devices, and provides 
many modes of protection for these files. A user can 
specify that his files be accessible only to himself, or 
be accessable only to specific individuals other than 
himself. Various modes of access can be specified, 
for read-only purposes and for both reading and 
writing. 


User Commands 


A terminal user can request the system to take certain 
actions in his behalf. Each action that he can specify 
is a command which, in the case of a typewriter-like 
terminal, is a one-line message. Commands are 
always acted upon by the Command-Language Inter- 
preter, which receives the incoming message, scans 
it to determine the nature of the action requested, and 
fetches from the system files the command program 
that will carry out the action. 

The command system ‘(the set of actions that the 
Command-Language Interpreter can recognize) pro- 
vides the capability for a program to be: 

1. Entered from the terminal, line by line with 
immediate diagnostic feedback from the system 
after each line. 

2. Cataloged, stored permanently in the system for 
later manipulation, and then made part of the 
user's prestored library. 

3. Compiled or assembled. 

4. Executed. 

The user appears to the system as an active 
terminal that is presenting a series of tasks to be 


performed. As long as these tasks are system com- 
mands, the system fetches its own programs and 
executes them on behalf of the user. System com- 
mands are similar to user programs in that they are 
time shared and multiprogrammed during execution. 
When the user initiates execution of his own program, 
he retains complete control over it. Thus the com- 
mand system also allows a program to be: 


e Stopped 

e Modified or displayed (for debugging purposes) 
e Restarted 

e Terminated. 


Beyond the basic capabilities of entering, execu- 
ting, and controlling programs from terminals, the 
command system provides for system accounting and 
file maintenance. 


System Accounting 


A user must LOGON at a terminal before any other 
action can be taken, and LOGOFF when his terminal 
operations are complete. These commands identify 
the user to the system and initiate time charges to the 
user for services rendered. If, in succeeding com- 
mands, he requests access to files, his identity will 
be matched against file-protection and security data, 
to insure file integrity and to prohibit unauthorized 
access to files. 


File Maintenance 


A user can request that his files be moved from one 
storage unit to another or be removed from the sys- 
tem. He can also modify them, combine them, or 
change their protection status. Commands can be 
initiated from terminals, as previously described, or 
they can in most cases be embedded in programs as 
the equivalent of subroutine calls. Commands can 
also be included as "control card'' functions to specify 
the type of processing to be applied to batch jobs enter- . 
ing the system. 

The command system allows the user to direct 
the system in its manipulation of files and in the 
solution to problems. More than this, however, itis 
the universal interface between the system and the 
outside world. From the machine-room console, for 
example, installation personnel control recovery 
functions of the system, using special commands re- 
served only for their use. Batch jobs entering the 
system from peripheral equipment or tape drives are 
controlled by the command system. 
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Paging 


Every program using the system is treated as a se- 
quence of 4096-byte units called "pages". By dividing 
programs up into pages, processor storage can be 
allocated in page (4096-byte) increments. Program 
pages, therefore, can be located randomly throughout 
core storage and swapped in and out of processor 
storage as pages are needed, commensurate with 
available space. Random location of pages for a 
given program necessitates the construction of tables 
(page tables) that reflect the processor storage lo- 
cation of the pages. The swapping of pages between 
auxiliary storage and processor storage is defined as 
"page turning’. If a page of instructions refers to a 
program location not currently in processor storage, 
the system will stop operating the program temporarily, 
make arrangements to fetch the page from auxiliary 
storage (the disk and drum storage space reserved 
specifically for paging), and perform other operations 
in the interim, 

Page turning has the following advantages: 

1. The entire program need not be in core storage to 
operate. Parts of many programs can be present, 
and several may be ready for processing. Thus, 
the system has many opportunities to do useful 
work while a page is being swapped. 

2. Program 'swap time" is reduced as an overhead 

factor since only active pages of a program re- 

quire movement between core storage and auxili- 
ary storage. 

Although written and executed as a classical set 

of contiguous instructions and working space, a 

program can exist in the machine as scattered 

active pages. 

The programmer's concept of the program being 

executed is of a "virtual storage" rather than of an 

actual processor storage situation. 

The user's virtual storage is the contiguous 
address space that would be needed to store the user's 
program, This virtual storage is not limited by actual 
processor storage size but is limited only by the 
available auxiliary (disk and drum) space. Theoret- 
ically, the programmer has 16 million bytes (24-bit 
addressing) or up to 4 billion bytes (optional 32-bit 
addressing) of virtual storage at his disposal. 


Segmentation 


System/360 24-bit addressing enables a 4096-page 
virtual storage. Virtual storage has been divided into 
16 segments containing 256 pages each. A segment 
table with only 16 entries accounts for all virtual 
storage. When a page of the user's program is moved 
from virtual storage to processor storage, the location 
of the page is recorded in a page table. The entrics in 


the page table are Sequential by virtual address. The 
location of the page table is recorded in the segment 
table. | 

Since each segment contains 256 pages, the page 
table cannot contain more than 256 entries. If the 
program occupies more than one segment of virtual 
storage, a page table is established for each segment 
as itS pages are moved to processor storage. Many 
segments can be used to organize a user program in 
virtual storage. Large working areas can be assigned 
virtual storage space. However, only an actual refer- 
ence to a segment will result in the generation of a 
page table for that segment. This avoids reserving 
large areas in page tables for pages not currently in 
use. 


EQUIPMENT CHARACTERISTICS 


Dynamic Address Translation 


Dynamic address translation is the process of conver- 
ting virtual addresses into actual processor storage 
addresses during instruction execution. A bit in the 
program status word (PSW) determines if translation 
is active or inactive. The translation feature is im- 
plemented in hardware in the processor. All proces- 
sor storage addresses that originate from the proces- 
sor, except for hardware generated addresses (PSW, 
etc.), are subject to translation. Storage addresses 
originating from the channels are not subject to 
translation. The basic feature provides for 24-bit 
addresses, whereas an optional feature provides trans- 
lation for either 24-bit or 32-bit addresses. 

Prefixing as described in the IBM System/360 
Principles of Operation manual is applied to each ad- 
dress after translation; i.e., if the translated address 
is in the range 0-4095, the address may be further 
modified under control of prefixing. Prefixing can 
be deactivated by a manual switch. 


Programming Note: Primary and alternate prefix 
areas must not be assigned within the first 
72K bytes ‘of physical storage. 


Extended PSW Mode 


The Model 67 can operate under control of Operating 
System/360 (OS/360, standard PSW mode) or under 
control of TSS/360 (extended PSW mode). Up to 
fourteen channels can be attached in duplex config- 
urations of the Model 67. Since this extended I/O 
capability requires additional interrupt masking cap- 
ability, additional control registers have been im- 
plemented in the processor; TSS/360 utilizes this 


additional capability by operating the Model 67 in the 
extended PSW mode. In addition, the PSW is rede- 
fined when the Model 67 is operating in extended PSW 
mode, 


High Resolution Interval Timer 


An interval timer with a high degree of resolution has 
been implemented in the processor. This timer sup- 
ports the time slicing technique, and is used with the 
TSS/360 dispatching and scheduling routines to signal 
the end of the time interval allotted to a given task. 
The operation of this timer is fully compatible with the 
timer operation described in the IBM System/360 


Principles of Operation manual. 
Storage Protection Extension 


Additional capability has been implemented in the 
Storage protection circuitry. The extended field of 
the storage protection key allows TSS/360 to evaluate 
the utilization of storage. If a reference is made to 
any location within a given block of storage, that fact 
is recorded in the protection key for that block. If the 
reference is a store operation, that fact is also re- 
corded in the protection key. This recording is always 
active and is independent of the CPU state of the in- 
struction or command being executed or of the manner 
in which the address is generated. The recorded in- 
formation is accessable to the standard ‘insert storage 
key' instruction. The increased field size affects only 
the set storage key and 'insert storage key' instruc- 
tions; the size of the PSW and channel address word 
(CAW) protection key fields are unchanged. 


Partitioning 


Partitioning is the division of a duplex configuration 
into two isolated subsystems. Partitioned units are 
made unavailable to part of the system for program- 
med control. This facility is implemented in units 
that have more than one interface to a processor- 
controlled subsystem. Each interface is equipped 
with a manual switch. This switch, together with a 
configuration-control bit in the processor and the 
"wait" state of the processor, control the partitioned 
status of all units in the system. Each processor can 
sense the status of all partitioning switches, regard- 
less of the partitioned status of the processor. 


Floating Addressing 
Processor Storage 


In a duplex configuration, the total bank of high speed 
processor storage is composed of several individual 











shared storage units. Each storage unit contains an 
increment of the total storage capacity in consecutive, 
unique addresses. In a time shared system, this bank 
of storage is exposed to partitioning into several parts 
for use by independent subsystems. Thus, each unit 
can be reassigned any one of the address intervals 
possible in the given system. For example, config- 


urations of four storage units providing a total of 1024K 
bytes of processor storage could be addressed as 
follows: 





Address Interval 
Unit A | UnitB | Unit C 


768K-1024K 


Configuration 














Unpartitioned | 000-256K | 256K-512K | 512K-768K 





Partitioned 000~256K | 256K-512K | 000-256K 256K-512K 








Unit A Out for 000-256K 256K-512K | 512K-~768K 


Maintenance 












Many different arrangements are possible, espe- 
cially with a system that has as many as eight proces- 
sor storage units. A single unit can be shared by two 
subsystems, or more than one unit can be shared by 
two subsystems. The example shows that more than 
one unit can contain the Same address interval. Parti- 
tioning controls prevent a single address from aces- 
sing two units that contain the same address interval. 
In a Single-processor configuration, the floating ad- 
dressing capability is invoked when address reassign- 
ment is needed because a processor storage unit has 
failed. 


Channel 


In a duplex system, channels are controlled and 
attached to the system via a Channel Controller 
(see Figure 2). Channel addressing is defined by 
the Channel Controller to which a given channel is 
attached; for example, channels 0-6 are attached to 
Channel Controller 0, channels 8-14 are attached 
to Channel Controller 1. This kind of channel ad- 
dressing is possible with TSS/360 if the CPU is in 
extended PSW mode operation. Channels are ad- 
dressed as 0-6 when the system is operating in 
standard PSW mode (OS/360). 

Floating channel addressing permits addresses 
0-6 to be assigned to either Channel Controller; for 
example, a partitioned system that contains Channel 
Controller 1 (channel addresses 8-14) can be assigned 
‘channel addresses 0-6. Therefore, OS/360 can be 
run on either subsystem, and TSS/360, OS/360, or a 
maintenance function can occupy the remaining sub- 
system. 
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SYSTEM COMPONENTS 


Four new units are introduced by the Model 67. 

1. IBM 2067 Processing Unit 

2. IBM 2846 Channel Controller 

3. IBM 2167 Configuration Unit 

4. IBM 2365 Processor Storage Model 12 

The following paragraphs contain a detailed descrip- 
tion of these units. 


IBM 2067 PROCESSING UNIT 


The IBM 2067 Processing Unit is available in two 
models. The 2067-1 is used for single processor 
configurations only. It is characterized by direct 
attachment of up to seven channels, storage control 
both for the processor and for channels, and a direct 
control feature capable of controlling and/or synchro- 
nizing special external devices. The 2067-2, designed 
for use in duplex configurations, is characterized by 
addressing capability for 14 I/O channels, attachment 
of a maximum of two Channel Controller units, pro- 
cessor storage control, and an extended direct con- 
trol feature capable of communicating control infor- 
mation between two 2067-2s. When a 2067-1 is used, 


the configuration is called a Model 67-1 system; 
when two or more 2067 Model 2s are used, the con- 


figuration is called a Model 67-2 system. These 
systems are shown in Figures 1 and 2. 

The 2067 contains the facilities for (1) addressing 
processor storage, (2) instruction decoding and 
execution, and (3) performing arithmetic and logical 
functions. Except where otherwise noted, the follow- 
ing descriptions apply to both models of the 2067 and 
to 24-bit addressing. 


Processor Storage Addressing 


The Bus Control Unit (BCU) located in the CPU con- 
trols processor storage addressing. Addresses are 
communicated to processor storage via a storage 
address bus (a multiplex bus since it is connected 
from the BCU to each Processor Storage Unit in a 
chain-like fashion). The BCU sends a select storage 
signal to each Processor Storage Unit; this signal 
requests a storage cycle and identifies the storage 
unit which is to sample the address bus. 

One difference between the 2067-1 and the 2067-2 
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is the functions performed by the BCU. In the 2067-1, 
the BCU provides access to processor storage both for 
processor references and for channel requests. The 
2067-2 BCU accesses processor storage for the CPU 
only. In configurations using a 2067-2, channel re- 
quests are communicated to processor storage via 

the Channel Controller. 

When handling CPU storage requests, the BCU 
stops the CPU clock when the channel has taken 
priority, when the referenced Processor Storage 
Unit is busy, or when the data required on a fetch 
cycle has not arrived in the time expected by the 
CPU. 


Floating Addressing 


Floating storage addressing switches distribute select 
Signals to the appropriate Processor Storage Unit. 
One eight position switch is associated with each Pro- 
cessor Storage Unit. These positions correspond to 
the address intervals possible in any system. A 3-bit 
field from the actual address is decoded into one of the 
eight possible selection signals (Figure 4). The unit 
associated with the switch that is selecting the inter- 
val will (1) receive the request for a storage cycle 

and (2) sample the address from the address bus when 
the request is honored. This decoding and selection is 
accomplished in the BCU of the CPU and Channel 
Controller. 


Dynamic Address Translation 


Another factor affecting the addressing of processor 
storage is dynamic address translation, which re- 
cords the relationship between the virtual address 

and the physical storage address used. This record is 
important to the segmentation and paging techniques | 
previously described. The processor storage location 
of each user's page is recorded sequentially in a page 
table by virtual storage address. The page table's 
starting address is recorded in the user's segment 
table (Table 1) which is loaded in processor storage. 
Each time the user is given control of the processor, 
the starting address of the segment table is loaded 
into control register 0 (the segment table register) 

by the control program. 
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* Storage unit 1 will be selected by addresses between 562K and 768K. 


** Storage unit 8 will be selected by addresses between 1563K and 1792K. 


Figure 4, Address Interval Assignment 


The virtual address operand is formed from the 
base address, index, and/or displacement as deter- 
mined by the instruction format. The resulting 
virtual operand address has three parts: 





19 20 


Each part of this virtual address is used to retrieve 
the physical address of the operand (Figure 5). 

The physical address of the operand consists of 
a byte address (12 low-order bits) and a page address 
(12 high-order bits). Bits 20-31 of the virtual address 
provide the byte address and bits 0-11 of a page table 
entry are the source of the page address. The segment 
address and page addresses in the virtual address are 
used to locate the appropriate page table entry. 

The segment table register (control register 0) 
contains the address, in processor storage, of the 
segment table. The segment table contains one entry 
for each segment (this entry is the address of the page 
table for that segment). The segment address (from 
the virtual address) is added to the segment table 
origin to locate the page table origin for that segment. 


Table 1. Format of Registers and Entries 


Bits | Meaning Remarks 


1. Segment Table Register Format: 
0-7 Segment Table Length* Indicates the number of 16-entry 

groups in the segment table. 

All zero = One group. 

8-3] Since the segment table origin is 


located on a 64-byte boundary, 
bits 26-31 must be zero. 


Segment Table Origin 


2. Segment Table Entry Format: 
0-7 = Page Table Length Indicates the number of entries in 

the page table. 

All zero = One entry. 

8-30 


Page Table Origin The page table origin is located 


on a 2-byte boundary. 
31 Page Table Availability 1 = Segment translation exception 
(program interrupt code 16). 


3. Page Table Entry (Halfword): 


0-11 Physical Block Address Starting addresses of page. 


12 Page Availability 1 = Page translation exception 


(program interrupt code 17). 


13-15 Control Bits, Reserved Must be 000 or specification 


exception. 


* Used only with CPU's that contain the 32-bit addressing feature. 
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Figure 5. Data Flow for Dynamic Address Translation (24-Bit) 


Then, the page address (from the virtual address) is 
added to the page table origin. This locates the 
physical starting address of the page in processor 
storage. (The page table contains a maximum of one 
entry for each page in the segment.) The byte ad- 
dress from the virtual address is then combined with 
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the page starting address to form the physical operand 
address (Table 2). 


To avoid repeating this translation process for 
every memory reference by a user program, the page 
table entry (page starting address, bits 8-19) is re- 
corded with, and identified by, its virtual address 


Table 2. Bit Alignment of Address Arithmetic 


1. Segment Table Entry Address 


Bits 
(24-Bit Mode) Meaning 


8-31 Table Origin 

8-11 Added to Logical 
Address 

8~31 Yields Sum 

Bits 

32-Bit Mode) Meaning 

8-31 Table Origin 

0-11 Added to Logical 
Address 

8-31 Yields Sum 


Remarks 


Bits 26-31 are considered zero. 


Aligned with 26-29 of segment 
table origin. 


Segment table entry address 
(30-31 always zero). 
Remarks 

26-31 are considered zero. 


Aligned with 18-29 of segment 
table origin. 


Segment table entry address 
(30-31 always zero). 


2. Page Table Entry Address - Either 24- or 32-Bit Mode 


Bits Meaning 

8-31 Page Table Origin 

12-19 Added to Logical 
Address 

8-31 Yields Sum 


3. Physical Address Result 


Bits Meaning 
0-11 Page Table Entry 
20-31 Logical Address 


8-31 Physical Address 


Remarks 
31 is considered zero. 


Aligned with 23-30 of page 
table origin. 


Page table entry address (31 is 
always zero). 


Remarks 
The high-order portion. 
The low-order portion. 


Both portions taken together. 


(segment and page address, bits 8-19) in an associa- 


tive storage register. 


If a subsequent reference is 


within that virtual page, the virtual address accesses 


the associative register. 


The page starting address 


stored in the register is affixed to the byte address 


and forwarded to the BCU. 


Eight associative storage registers are in the 
associative array; each stores an individual page 
address (Table 3). Bits 36 and 37 of each register 
reflect the validity and the usage of that entry, 


respectively. 


Both bits are set to 1 when the regis- 


ter is loaded, and both are reset to 0 when the seg- 
ment table register (control register 0) contents are 


changed. 


If, within a user's time slice, eight separ- 


ate pages are referenced (i.e., all associative regis- 
ters have been loaded and each bit 37 is a 1), all bit 


378 are reset to 0. 


Subsequent references to a reg- 


ister will cause bit 37 for that register to be set. 
During subsequent translations, the result will be 
loaded into the lowest-numbered register that has a 


Table 3. Associative Register Format 


24-Bit Addressing: 


Bits Content Remarks 

8-19 Virtual Address 

20-31 Physical Address The page address from a previous 
translation which corresponds to 
the virtual address in bits 
8-19. 

32-35 Unassigned* 

36 Register Valid Set to 1 upon loading the register. 

37 Recent Usage - Set to 1 upon loading the register 

"Load" and upon any use thereafter. 
38 Disable Set with special diagnose codes 


8-15. 


32-Bit Addressing: 


Same as above except for virtual address, which 
is in bits 0-19. 


* For expansion; not physically implemented . 


0 ina bit 37. Bit 37 is set toa 1 asa result of this 
load. With this technique, the associative array al- 
ways contains the most recent and/or most frequent- 
ly used page addresses. 

Since instructions frequently occur in sequence, 
an "IC register" is implemented to hold and provide 
the translated page address for use in serial instruc- 
tion sequences; this avoids repeated accesses of the 
page address from the associative array. 

Dynamic address translation applies only when 
the CPU is operating in extended PSW mode. Bit 5 
of the extended PSW controls whether translation is 
active (bit 5=1) or inactive. When translation is 
active, all program-generated processor storage 
addresses originating from the CPU are subject to 
translation; hardware-generated addresses (e.g., 
from timer, new PSW fetch, old PSW store, etc.) 
and storage addresses originating from the channels 
are not subject to translation. 

Prefixing is applied to the address after transla- 
tion. If the translated address is in the range of 
0-4095, further address modification under control 
of prefixing might occur. A switch on the 2167 con- 
trol panel can be used to manually deactivate pre- 
fixing. The basic prefixing feature provides trans- 
lation for 24-bit addresses, whereas an optional 
feature provides translation for either 24-bit or 
32-bit addresses (Figure 6). Bit 4 of the extended 
PSW indicates whether 24-bit or 32-bit address com- 
putation arithmetic should apply. 


Timin 


Instruction execution timing in the 2067 is affected by 
the dynamic address translation process as follows. 
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Figure 6. Data Flow for Dynamic Address Translation (32-Bit) 


When dynamic address translation is active and the 
translated address is in the associative array, no 
table references are required. The necessary physi- 
cal address is made available in 150 nsec, thus adding 
150 nsec to each storage reference for an operand. 
Consecutive instructions addressed sequentially incur 
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the additional 150 nsec on the first array reference 
only. Succeeding instructions in the sequence use the 
translated address from the instruction counter regis- 
ter which adds no additional time to the operand re- 
ference. 


Instructions which are located in a different page, 


or which are in the same page block but are reached 
by branching require either the 150 nsec as above, or 
the longer lookup time as described in the following 
paragraph, 

When address translation is active and the physi- 
cal address is not in the associative array, transla- 
tion is obtained through two storage references. Thus, 
the approximate time required is: (1) two storage 
references, one each for segment table and page table 
entries, plus (2) the storage reference for data, plus 
(3) 750 nsec. The exact time depends on the other 
CPU or Channel Controllers requiring access to the 
same storage unit during the translation operation. 


Channel Addressing 


The 2067-1 can attach up to six selector channels and 
one multiplexer channel. Channel and device addres- 
sing is performed as described in the IBM System/360 
Principles of Operation manual. There is very little 
difference in channel address handling when the 2067-1 
is operating in standard PSW mode or in extended PSW 
mode. 

The 2067-2 can attach two Channel Controllers, 
each of which can attach up to seven channels. Chan- 
nel addressing is preceded by selection of a Channel 
Controller. The channel address field of the effective 
address formed by an I/O instruction is expanded to 
provide for Channel Controller addressing. In the 
extended PSW mode of operation, bits 16-20 of the 
effective address are decoded to select one Channel 
Controller. Addresses 00100 through 11111 are de- 
coded as invalid channel addresses. Instructions that 
specify these addresses are terminated without selec- 
tion of a 2846, and condition code 3 is set into the PSW. 

When the 2067 is operating in standard PSW mode, 
the channel controller compatibility addressing switch 
controls selection of a Channel Controller. The setting 
of this switch determines the Channel Controller to 
which the start I/O signal, I/O interrupt mask bits, 
channel and device addresses, etc. will be distributed. 
Since either Channel Controller can be selected for use 
by the CPU that is operating in standard PSW mode, 
1/O instructions in programs that operate in standard 
PSW mode must address Channel Controller 0 (i.e., 
bits 16-20 of the channel address field must be 0s). 

When the system is in the standard PSW mode, the 
storage protection key is sent to the Channel Controller 
specified by the channel controller compatibility ad- 
dressing switch. 


Instruction Fetching and Execution 


The PSW controls instruction sequencing and holds 
and indicates the status of the system relative to the 
program currently being executed. When operating 


in the standard PSW mode, the PSW format is iden- 
tical to the format described in the IBM System/360 
Principles of Operation manual. The PSW format 

is redefined as follows when operating in the extended 


PSW mode: 
24-32 : 
: Tran.| i/O |Ext. | Protec. Prog. 
cc 
ie ied Side oa Rte [an ne fee sas 
0 3. 4 5 6 7 8 11:12) «15 16 17 18 19 20 23 24 31 


( | Instruction Address | 








32 63 

0-3 Spare (must be 0 s) 

4 24-32 Bit Address Mode 

5 Translation Control 

6 I/O Mask (Summary) 

7 External Mask (Summary) 

8-11 Protection Key 

12 ASCII-8 Mode (A) 

13 Machine Check Mask (M) 

14 Wait State (W) 

15 Problem State (P) 

16-17 Instruction Length Code (ILC) 

18-19 Condition Code (CC) 

20-23 Program Mask? 
20 Fixed Point Overflow Mask 
21 Decimal Overflow Mask 
22 Exponent Underflow Mask 
23 Significance Mask 

24-31 Spare 

32-63 Instruction Address 


The content of several PSW fields is further 
specified, as follows. Unless bits 0-3 are 0s, a 
specification exception is generated. When the 32- 
bit addressing option is not installed, bit 4 must be 
0. Specification exceptions are generated if this 
format is violated. These specification exceptions 
are recognized either during the execution of the 
instruction that follows the loading of the PSW, or 
following the 'set system mask' instruction. 
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Fetching 


Instruction fetching by the CPU (1) retrieves machine 
instructions from the storage units, and (2) performs 
the operations common to many instructions. More 
specifically, the instruction fetching process insures 
a correct value in the instruction counter, fetches in- 
structions from storage, determines the format 

(RR, RX, RS, SI, and SS) of the fetched instructions, 
and loads the appropriate registers with operands and 
data fields. Then control is transferred to the execu- 
tion phase, in which specific machine instructions 
are decoded and executed. 

Each instruction fetch retrieves one doubleword 
from storage. Since instructions vary from one to 
three halfwords in length, as few as 1 1/3 instructions 
(SS format) or as many as four complete instructions 
(RR format) can be retrieved from the processor 
storage unit during one fetch operation, The instruc- 
tion counter is incremented by 8 each fetch operation. 

Operands specified by RR format instructions 
are placed directly into the desired data flow regis- 
ters during the instruction fetch operation. Oper- 
ands specified by RX, RS, SI, and SS format in- 
structions require effective address generation; 
when the effective address is calculated, control is 
passed to the operations necessary to complete ex- 
ecution of the instruction. 


Execution 


Instruction execution is a series of functional opera- 
tions performed in a specific sequence. 
tions are determined by the operation code of the in- 
struction to be executed and by certain other environ~ 
mental conditions; frequently, the relative importance 
of these environmental conditions is a function of the 
type of instruction currently controlling the CPU. 
Read-only storage (ROS), a fundamental device within 
the 2067, controls instruction execution. Each ROS 
address contains predetermined information that is 
used as required during instruction execution to con- 
trol data flow. The program does not address ROS; 
instead, ROS operations are directed by conditions 
established by specific instructions and/or by their 
execution. Information in ROS is indestructible, and 
can be modified only by physically changing the ROS 
element. 


Interruptions 


Since the Model 67 has extended I/O capability with 
respect to the standard System/360, it has expanded 
control over I/O interruptions. This control is ac- 
complished by using additional control registers in 
the 2067. Both logic registers and switch registers 
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These opera- 


(partitioning switches) are used as control registers 
(Table 4). 


Table 4. Control Registers 
Register Bit Position Assignments 
0 Segment Table Register (for Dynamic Address Translation) 
1 Unassigned* 
2 Translation Exception Address Register 
3 Unassigned* 
4 Extended Mask Registers for I/O Channel Masks 
5 Unassigned* 
Bits O, 1: Machine Check Mask Extensions for 
Channel Controllers 
Bits 2, 3: Reserved 
Bits 4-7: Unassigned* 
Bit 8: Extended Contro! Mode 
Bit 9: Configuration Control Bit; defines when 
partitioning can take place. 
Bits 10-23: Unassigned* 
Bits 24-31: External interruption masking as follows: 
Bit Position Interruption Source 
24 Timer 
25 Interrupt Key 
26 Malfunction Alert = CPU 1 (Ext. Sig. 2) 
27 Malfunction Alert - CPU 2 (Ext. Sig. 3) 
28 Reserved (Ext. Sig. 4) 
29 Reserved (Ext. Sig. 5) 
30 External Interrupt - CPU 1, 2 (Ext. Sig. 6) 
31 Reserved (Ext. Sig. 7) 
7 Unassigned 
8-14 Partitioning Sensing Registers. See 2167 description for 
, register layout. 
15 Unassigned* 


* For expansion; not physically implemented. 


The CPU distributes one machine check mask bit 
to each Channel Controller. Control register 6 
(external machine check mask register) bits 0 and 1 
are used for this function. Distribution of these 
mask bits is not affected by the PSW mode of opera- 
tion and is independent of the channel controller 
compatibility addressing switch; PSW bit 13 is a 
summary mask for all machine check interrupts. 
The following situations are possible: 


Control 
PSW Register 6 
Bit13 BitO  Bit1l Remarks 
0 x x Regardless of the status of 
bits 0 and 1 of control regis- 
ter 6, all machine checks 
are masked off by PSW bit 
13. 
1 0 0 Only CPU machine checks 
will be recognized. 
1 0 A: CPU and Channel Controller 
1 machine checks will be 
recognized. 
1 1 0 CPU and Channel Controller 
0 machine checks will be 
recognized. 
1 1* a All machine checks will be 


recognized, 


*These bits are set to 1 by system reset. Program 
systems, other than TSS/360, that do not contain 
instructions for modifying control register 6 must 
use PSW bit 13 for control over machine check in- 
terruptions, 


Control register 6 also contains external inter- 
rupt mask bits. This field is added to control register 
6 by the extended direct control feature. Bits 24 
through 31 of control register 6 are always active as 
mask bits and are not affected by mode changes of 
the PSW. They are all set to 1 by system reset, 
power on reset, initial program load, IPL and ex- 
ternal start. Bit 7 of either PSW is a summary 
mask for external interrupts; it must be a 1 for any 
external interrupts to be recognized. 

The Model 67 is compatible with the interrupt 
capabilities described in the IBM System/360 Princi- 
ples of Operation manual. In addition, the following 
program- and machine~-check interruptions are re- 
cognized. 


Program Interruptions 
Specification Exception: A specification exception 


(interruption code 6) also is recognized: 
1. When bit 4 of the extended PSW is a 1 when 


the 32-bit addressing option is not installed. 
2. When bits 0-3 of the extended mode PSW are 
not 0s, or 
3. When bits 13-15 of the page table entry 
accessed during an address translation 
are not 0s. 


Specification exceptions relating to the 
extended PSW are recognized during execution 
of the instruction that follows the loading of the 
PSW or follows the 'set system mask' instruction. 
For the situation listed as item 3 above, the 
operation is suppressed. The instruction length 
code is 1, 2, or 3. 


Data Exception: Data exception (interruption code 7) 
is also generated if bits 26-31 of the segment 
table register (control register 0) are not Os. 

It is recognized following execution of the in- 
struction that loads the segment table register. 
When data exception is recognized, the resulting 
interrupt request is handled as described in the 
IBM System/360 Principles of Operation manual. 
The operation is terminated, and the instruction 
length code is 2. 


New Exceptions: Because of dynamic address trans- 
lation, two entries are added to the list of pro- 
gram interruptions: 





Interruption Code 
Program Interruption 
Dec | Hex | Binary Cause 


16 | 10 | 0001 0000 











Segment Translation 






0001 0001 


Page Translation 





A segment-translation exception is recognized: 

1. When 32-bit addressing (bits 0-7 of the 
segment table register indicate the segment 
table length) and the quantity in bits 0-7 of 
the logical address is greater than the seg- 
ment table length, or 

2. When the segment table entry is accessed 
and bit 31 is ail. (Bit 31 indicates the 
availability of a page table for that segment, 
and is 0 when a page table has been estab- 
lished for that segment.) 
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A page-translation exception is recognized: 

1. When the quantity in bits 12-19 of the logical 
address is greater than the page table 
length. (The quantity in bits 0-7 of the seg- 
ment table entry is the page table length.) 

2. When the page table entry is accessed and 
bit 12 is a1. (Bit 12 of the page table entry, 
the availability bit, is 0 when the page repre- 
sented by that entry is in the core address 
identified by the entry.) 

Whenever a segment- or page-translation 
exception is recognized, the instruction is sup- 
pressed and storage is not modified. The virtual 
address that was to be translated is recorded in 
the translation exception address register (con- 
trol register 2) and, ifin 24-bit addressing mode, 
bits 0-7 are made 0s. The instruction length 
code for both exceptions may be 1, 2, or 3. 


Machine Check Interruption 


In addition to the machine check capability described 
in the IBM System/360 Principles of Operation man- 
ual, the 2067 performs machine checking on the dy- 
namic address translation unit. Additional informa- 
tion about the machine check interruption is stored 
in the first byte (bits 0-7) of the translation exception 
address register (control register 2). Bits 50-54 in 
the maintenance control word indicate to the monitor 
whether a dynamic address translation unit machine 
check has caused the interruption; if it has, a 1-bit 
in the translation exception address register will in- 
dicate one of the following conditions: 


Bit Condition 
0 More than one associative register contains 
identical information, or one of the compar- 
ing circuits is at fault. 
1 A successful compare is achieved with a 
virtual address that is higher than the ad- 


dresses in the segment table. 


2 The virtual address portion of the translated 
address just stored in the associative array 
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does not compare with the virtual address 
that should have been‘stored. 


3 A reset of the load-valid bits in the associa- 
tive array was unsuccessful. 


4 Parity of the adder sum is inconsistent with 
the predicted parity. 


5 Parity of the virtual address was incorrect 
when received by the associative array. 


6 Parity of the data word from storage was 
incorrect when received by dynamic ad- 
dress translation circuitry. 


7 Parity of instruction bits 8-15 was incorrect 
when received by dynamic address translation 
circuitry. 


When a machine check interruption is recognized, 
execution of the instruction is terminated and the 
interrupt request is handled as described in the IBM 
System/360 Principles of Operation manual except as 
follows. When a machine check interrupt is caused by 
an external machine check (I/O machine check), the 
CPU (1) completes execution of the current instruc- 
tion, (2) does not initiate an internal diagnostic pro- 
cedure, and (3) does not perform a diagnostic scan 
out into the storage area beginning at location 128. 
For both machine check and external machine check, 
the CPU stores the old PSW in location 48 and loads 
the new machine check PSW from location 112. Bit 
17 of the old machine check PSW identifies the CPU 
mode of operation at the time of interruption. Bit 
17 is stored as a 1 when the CPU is in extended PSW 
mode and as a 0 in standard PSW mode. The high- 
order bit of the interrupt code (bit 16 of old machine 
check PSW if the CPU is in standard PSW mode) in- 
dicates whether the machine check is an external 
machine check. This high-order bit is a 1 for ex- 
ternal machine checks and a 0 for CPU machine 
checks, 


Interrupt Codes 


In extended PSW mode, when the PSW is stored as the 
old PSW, the 16-bit interruption code is stored as a 
halfword in storage as follows: 


Interruption Type Permanent Storage Address 


Decimal Hex 
External 14-15 E-F 
SVC 16-17 10-11 
Program 18-19 12-13 
Machine check 20-21 14-15 
1/O 22-23 16-17 


These bytes are not loaded when loading a PSW. 
Extended Direct Control 


The extended direct control feature enables direct 
communication of control information between two 
CPU's. Each CPU in a duplex system must be 
equipped with this feature. Extended direct control 
is a modification of the multisystem operation and the 
direct control feature described in the IBM System/ 
360 Principles of Operation manual. Two major 
modifications have been implemented by this feature. 
The 'read direct' instruction has been made an in- 
valid instruction and the 'direct-out' lines are termin- 
ated within the CPU. Since the duplex configuration 
of the Model 67 is a shared storage system, there is 
no need to transfer a data byte over the 'direct-out' 
lines to the other CPU. Another CPU's attention can 
be directed to an area of shared storage via the ex- 
ternal interruption signal lines. 

The extended direct control feature uses the 
'write direct' instruction and six external interruption 
lines: 


Interrupt 
Line CPU 1 CPU 2 
2 Not used Machine check out 
signal from CPU 1 
3 Machine check Not used 
out signal from 
CPU 2 
4,5 Reserved for future use 
6 Timing signal Timing signal from 
from CPU 1 or CPU 1 or CPU 2. 
CPU 2 
7 Not used Not used 


Line numbers correspond to external signal designa- 
tions used with the interruption codes listed in the 
IBM System/360 Principles of Operation manual. 
Interrupt codes and mask bits for these lines are as 
follows: 


Control Register 6 
External Interrupt 


Line Mask Bit Interruption Code 
2 26 00000000 nninnnnn 
3 27 00000000 nnninnnn 
6 30 00000000 nnnnnnln 


WRITE DIRECT is used in the Model 67 to gen- 
erate the timing signal external interrupt request 
(line 6) and the external start signals. The I2 field of 
the instruction is divided into two fields by function. 
Bits 8 - 11 are assigned to the external interrupt func- 
tion, and bits 12 - 15 are assigned to the external 
start function. Bit 8 is assigned to CPU 1 and bit 9 
is assigned to CPU 2. Regardless of which CPU 
executed the 'write direct' instruction, a 1 in bit 9 
of the I, field will generate external interrupt sig- 
nal on line 6 of CPU 2. A CPU can interrupt itself. 

Bit 12 of the Ip field is assigned to start CPU 1 
and bit 13 is assigned to start CPU 2. Since there is 
a main 'external start' line and an alternate 'external 
start' line for each CPU, bit 7 (low-order bit) of the 
data byte addressed by the 'write direct’ instruction 
is used with the Ip bit(s) to generate the appropriate 
external start signal. For example, if bit 12 (of the 
I field) is a 1 and bit 7 (of the data byte) is a 0, a sig- 
nal is generated on the main ‘external start' line of 
CPU 1. When bit 12 is a 1 and bit 7 is a1, a signal 
is generated on the alternate 'external start' line of 
CPU 1. Note that CPU 1 is started regardless of 
which CPU executed the instruction. ''Main" and 
"alternate" correspond to the main and alternate pre- 
fix values prewired in each CPU. More than CPU can 
be signaled by one 'write direct' instruction. The 
external start signal pre~empts current operations 
in the receiving CPU. The current operation is ter- 
minated, the current PSW is replaced by the contents 
of the new PSW at byte address 0000 (defined as the 
new external start PSW), and the current PSW is lost. 
Selection of the prefix value is a function of the line 
(main or alternate) on which the signal was received. 
A system reset of all control latches occurs in the 
receiving CPU, but the reset is not propagated to the 
I/O components. Therefore, the programmer must 
insure, by suitable programming constraints, that 
the receiving CPU is not executing an I/O instruction 
and is not accepting an I/O interrupt. If either of 
these conditions occurs simultaneously with receipt 
of the external start signal, the results are generally 
unpredictable and the I/O channel and/or channel 
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control unit may hang up. 

The external start sequence is completed after 
50 us. Results are unpredictable for successive 
external starts issued to one CPU more frequently 
than one every 150 us. 

Extended direct control can be partitioned by 
switches on the Configuration Unit. One switch per 
CPU can be set to remove the CPU from the external 
direct control interface. When the CPU is partitioned 
off, machine checkout and timing signals are not gen- 
erated, and external start and external interrupt-in 
signals are ignored (do not remain pending). When 
partitioned, a CPU cannot external start itself and 
cannot interrupt itself, although manual IPL (load) 
and the interrupt pushbutton are still effective. 


High Resolution Interval Timer 


An interval timer with a high degree of resolution is 
used in the 2067. Operation of this timer is fully 
compatible with that described in the IBM System/360 
Principles of Operation manual. 

The high resolution timer provides approximately 
13-microsecond resolution. This is accomplished 
with an 8-bit hardware register which contains the 
low-order byte of the timer. Each time the low- 
order byte counts to zero, the timer value at loca- 
tions 80-82 is decremented at the end of the instruc- 
tion currently being executed. 

An operand fetch from location 80 will retrieve 
the three high-order bytes from location 80 plus the 
low-order byte from the hardware register. If the 
low-order byte has stepped through zero during the 
instruction prior to a fetch from location 80, zeros 
are inserted into the low-order byte instead of the 
contents of the hardware register. Any instruction 
that stores into location 80 also stores the low-order 
byte into the hardware register as well as a full word 
into location 80. If the timer value at location 80 
changes from positive to negative, an external inter- 
ruption is requested. 


Programming Note: If the emulator feature is in- 
stalled and if the system is in emulator mode, 
a machine check is not indicated by the machine 
time-out feature, and the machine-check inter- 
ruption is lost. 


Interruption Times 
Interruption times vary for the class of interruption 


and for the type of instruction being executed at the 
time of the interruption. 
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External Interruption 


External interruption time is 3.15 microseconds; it 
extends from the time the external interruption is 
discovered and honored to the time the next instruction 
is started. 


Supervisor Call Interruption 


Supervisor call interruption time is 3.95 microsec- 
onds (including supervisor call instruction time); it 
extends from the time the external interruption is 
discovered and honored to the time the next instruc- 
tion is started. 


Program Interruption 


Program interruption time is 3.15 microseconds; it 
extends from the time the program interruption is 
discovered and honored to the time the next instruction 
is started. Actual interruption occurs at the end of 
the current instruction. 


Machine Check Interruption 


Machine check interruption time is approximately 25 
microseconds; it extends from the time the machine 
check interruption is discovered to the time the next 
instruction is started, and includes scan out and re- 
set time. 


I/O Interruption 


The I/O interruption time is 4.65 microseconds; it 
extends from the time that the CPU takes a pending 
interruption from the channel to the time that the old 
PSW and CSW are stored. 


Modified Instructions 


Bit 8 of control register 6 determines the 2067 mode 
of operation. When this bit is a 0, the PSW format 
is defined in the IBM System/360 Principles of Opera- 
tion manual (i.e. , channels beyond 6 cannot be ad- 
dressed and cannot cause interrupts). When this bit 
is a1, the PSW is interpreted as previously described 
for extended PSW mode. Upon system reset (gener- 
ated by manual system reset, manual IPL, or external 
start), bit 8 of control register 6 is set to 0. 

The following paragraphs describe the perfor- - 
mance of existing instructions as modified in extended 
PSW mode. 


Load PSW Instruction 


LPSW sD, (By) {s1] 


= ET 


0 7 1516 19 20 31 


The doubleword at the location designated by the oper- 
and address replaces the PSW. 

The operand address must have its three low- 
order bits 0 to designate a doubleword; otherwise, a 
specification exception results in a program interrup- 
tion, 

The doubleword which is loaded becomes the PSW 
for the next sequence of instructions. Bits 8-11 be- 
come the new protection key. Bits 32-63 of the 
doubleword become the new instruction address. 

The PSW is not checked for program interruptions 
during the load-PSW operation. These checks occur 
as part of the execution of the next instructions. 

Bits 16 and 17 of the PSW are not retained upon 
loading. They will contain the instruction length 
code for the last-interpreted instruction when the 
PSW is stored (1) during a branch-and-link operation, 
or (2) during a program or supervisor call interrup- 
tion. 


Condition Code: The code is set according to bits 
18 and 19 of the new PSW loaded. 


Program Interruptions: 


Privileged operation 
Protection (fetch violation) 
Addressing 

Specification 


Programming Note: The CPU enters the problem 
state when LOAD PSW loads a doubleword with 
a 1 to be consistent in bit position 15 and simi- 
larly enters the wait state if bit position 14 is 1. 
LOAD PSW is the only instruction available for 
entering the problem state or the wait state. 


Set Storage Key Instruction 


SSK Ry, Ry CER] 


poe fi | | 


0 78 1112 #15 


The key of the storage block addressed by the register 
designated by Roy is set according to the key in the 
register designated by Rj. 


The storage block of 2,048 bytes, located on a 
multiple of the block length, is addressed by bits 8-20 
of the register designated by the R, field. Bits 0-7 
and 21-27 of this register are ignored. Bits 28-31 
of the register must be 0; otherwise, a specification 
exception causes a program interruption. 

The 7-bit key is obtained from bits 24-30 of the 
register designated by the R, field. Bits 0-23 and 
bit 31 of this register are ignored. When fetch pro- 
tection is not installed, bit 28 of the register specified 
by the Rj is ignored. 


Condition Code: The code remains unchanged. 


Program Interruptions: 


Operation (if protection feature is not installed) 
Privileged operation 

Addressing 

Specification 


Insert Storage Key Instruction 


ISK =o Ry, Ros E RR} 


pe fa fe 


0 78 1112 «#15 


The key of the storage block addressed by the regis- 
ter designated by Rg is inserted in this register de- 
signated by R,. 

The storage block of 2,048 bytes, located on a 
multiple of the block length, is addressed by bits 
8-20 of the register designated by the R, field. Bits 
0-7 and 21-27 of this register are ignored. Bits 
28-31 of the register must be 0; otherwise, a specifi- 
cation exception causes a program interruption. The 
7-bit key is inserted in bits 24-30 of the register 
specified by the R, field. Bits 0-23 of this register 
remain unchanged, and bit 31 is set to 0. When 
fetch protection is not installed, bit 28 of the register 
specified by the R, field is set to 0. 


Condition Code: The code remains unchanged. 


Program Interruptions: 


Operation (if protection feature is not installed) 
Privileged operation 

Addressing 

Specification 


Translate and Test Instruction 


TRE = Dj (L, By), Do(Bo) ~—‘([SS] 
0 78 15 16 1920 3132 35 36 47 
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The 8-bit bytes of the first operand are used as 
arguments to reference the list designated by the 
second operand address. Each 8-bit function byte 
thus selected from the list is used to determine the 
continuation of the operation. When the function 

byte is a 0, the operation proceeds by fetching and 
translating the next argument byte. When the function 
byte is nonzero, the operation is completed by inser- 
ting the related argument address in general register 
1, and by inserting the function byte in general regis- 
ter 2. 

The bytes of the first operand are selected one 
by one for translation, proceeding from left to right. 
The first operand remains unchanged in storage. 
Fetching of the function byte from the list is perfor- 
med as in the translate instruction description. The 
function byte retrieved from the list is inspected for 
all-zero combination. 

When the function byte is 0, the operation pro- 
ceeds with the next operand byte. When the first 
operand field is exhausted before a nonzero function 
byte is encountered, the operation is completed by 
setting the condition to 0. The contents of general 
registers 1 and 2 remain unchanged. 

When the function byte is nonzero, the related 
argument address is inserted in the 24 low-order 
bits of general register 1. This address points to 
the argument last translated. The 8 high-order bits 
of register 1 remain unchanged. When operating with 
the 32-bit addressing option active, the related argu- 
ment address is inserted in all 32 bits of general 
register 1. 

The function byte is inserted in the eight low- 
order bits of general register 2. Bits 0-23 of regis- 
ter 2 remain unchanged. The condition code is set 
to 1 when one or more argument bytes have not been 
translated. The condition code is set to 2 if the last 
function byte is nonzero. 


Resulting Condition Code: 
0 All function bytes are zero 


1 Non-zero function byte before the first 
operand field is exhausted 

2 Last function byte is nonzero 

SD wesc ee ee 


Program Interruptions: 
Protection (fetch violation) 


Addressing 


Programming Note: TRANSLATE AND TEST is 
useful for scanning an input stream and locating 
delimiters. The stream can thus be rapidly 
broken into statements or data fields for further 
processing. 
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Edit and Mark Instruction 


EDMK = Dj(L, By), D2(By) Css] 


0 7 8 15 16 19 20 3132 3536 47 


The format of the source (the second operand) is 
changed from packed to zoned and is edited under 
control of the pattern (the first operand). The address 
of each first significant result digit is recorded in 
general register 1. The edited result replaces the 
pattern. 

The operation is identical to edit, except for the 
additional function of inserting a byte address in 
general register 1. The use of general register 1 is 
implied. The byte address is inserted in bits 8-31 
of this register. Bits 0-7 are not changed. When 
operating with the 32-bit addressing option active, 
however, the full 32-bit byte address is inserted in 
general register 1. For that situation, bits 0-7 may 
be changed. 

The byte address is inserted each time the 'S' 
trigger is in the zero state and a nonzero digit is 
inserted in the result field. The address is not in- 
serted when significance is forced by the significance- 
start character of the pattern, while inserting a fill 
character in the result field. 


Resulting Condition Code: 
0 Result is zero 


1 Result field is less than zero 
2 Result field is greater than zero 
3 


Program Interruptions: 
Operation (if decimal feature is not installed) 


Protection (store or fetch violation) 
Addressing 
Data 


Programming Notes: EDIT AND MARK facilitates 
the programming of floating currency-symbol in- 
sertion. The character address inserted in regis- 
ter 1 is one more than the address where a floating 
currency-sign would be inserted. The BRANCH 
ON COUNT, with zero in the Ro field, may be 
used to reduce the inserted address by one. 

The character address is not stored when 

significance is forced. Therefore, the address 
of the character following the significance-start 
character should be placed in register 1 prior to 
EDIT AND MARK. 


When a single instruction is used to edit several 
numbers, the address of the first significant digit 
of each number is inserted in general register 1. 
Only the last address will be available after the in- 
struction is completed. 


Load Address Instruction 


Dy (XqB.) [RX] 


1412) 15 16 «19 20 31 


For 24-bit addressing, the address specified by the 
X2, Bo, and Dp fields is inserted in bits 8~31 of the 
general register specified by Ry: Bits 0-7 are set 
to zero. The address is not inspected for availability, 
protection, or resolution. The address computation 
follows the rules for address arithmetic. Any carries 
beyond the 24th bit are ignored, and no storage refer- 
ences for operands take place. 

For 32-bit addressing, the address specified 
by the Xo, Bo, and D, fields is inserted in the gen- 
eral negister apeeiticd by R,;. The address is not 
inspected for availability, protection, or resolution. 
The address computation follows the rules for address 
arithmetic, Any carries beyond the 32nd bit are 
ignored, and no storage references for operands take 
place. 


Condition Code: The code remains unchanged. 


Program Interruptions: None 

Programming Note: The same general register may 
be specified by the R,,X and By instruction 
fields, except that sence at register 0 can be 
specified only by the R, field. In this manner, 
it is possible to increment the contents of a 
general register, other than 0, by the contents 
of the D, field of the instruction. The register 
to be incremented should be specified by R 
and by either X»5 (with By Set to 0) or By (with 
Xo set to 0). 


Supervisor Call Instruction 


SVC | [RR] 
a 
0 78 15 


The instruction causes a supervisor call interruption, 
with the I field of the instruction providing the in- 
terruption code. 

The contents of bit positions 8-15 of the instruc- 
tion are placed in byte locations 16-17 of core storage 
in the course of the interruption. The old PSW is 
stored at location 32, and a new PSW is obtained from 
location 96. The instruction is valid in both problem 
and supervisor state. 


Condition Code: The code remains unchanged in the 
old PSW. 


Program Interruptions: None 





Branch On Index High Instruction 


BXH Ry, Rg, Dy (By) —_—[RS] 


0 78 1112 15 16 19 20 31 


An increment is added to the first operand, and the 
sum is compared algebraically with a comparand. 

Subsequently, the sum is placed in the first operand 
location, regardless of whether the branch is taken. 


’ When the sum is high, the instruction address is 


replaced by the branch address. When the sum is 
low or equal, instruction sequencing proceeds with 
the updated instruction address. 

The first operand and the increment are in the 
registers specified by R, and R,. The comparand 
register address is odd and is either one larger than 
Ry or equal to Rg. The branch address is determined 
prior to the addition and comparison, 

Overflow caused by the addition is ignored and 
does not affect the comparison. Otherwise, the 
addition is ignored and does not affect the comparison. 
Otherwise, the addition and comparison proceed as in 
fixed-point arithmetic. All 32 bits of the general 
registers participate in the operations, and negative 
quantities are expressed in two's-complement notation. 
When the first operand and comparand locations coin- 
cide, the original register contents are used as the 
comparand. 


Condition Code: The code remains unchanged. 


Program Interruptions: None 


Programming Note: BRANCH ON INDEX HIGH indi- 
cates that one of the major purposes of this in- 
struction is the incrementing and testing of an 
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index value. The increment may be algebraic 
and of any magnitude. 

When BRANCH ON INDEX HIGH is used for 
address modification in a 2067 that is equipped 
with 32-bit addressing and bit 32 isalasa 
result of address modification, the resulting 
address will be treated as a negative quantity 
during the compare process; this can result 
in an erroneous branch. For that magnitude of 
address manipulation, care must be taken in the 
use of this instruction. 


Branch On Index Low or Equal Instruction 


BXLE Rye Rg, Dg (Bo) [RS} 


7 {afalel » | 


0 7 8 1172 15 16) «19 20 31 


An increment is added to the first operand, and the 
sum is compared algebraically with a comparand. 
Subsequently, the sum is placed in the first operand 
location, regardless of whether the branch is taken. 
When the sum is low or equal, the instruction address 
is replaced by the branch address. When the sum is 
high, normal instruction sequencing proceeds with the 
updated instruction address. 

The first operand and the increment are in the 
registers specified by R; and R,. The comparand 
register address is odd and is either one larger than 
Rg or equal to Rg. The branch address is determined 
prior to the addition and comparison. 

This instruction is similar to BRANCH ON INDEX 
HIGH, except that the branch is successful when the 
sum is low or equal compared to the comparand.,. 


Condition Code: The code remains unchanged. 


Program Interruptions; None 


Programming Note: The same exposure to erroneous 
branching exists for this instruction with 32-bit 
addressing during address modification as descri- 
bed for BRANCH ON INDEX HIGH. 


Set System Mask Instruction 


SSM D, (B,) [Sv 
os 


The byte at the location designated by the operand 
address replaces bits 0-7 of the current PSW. 
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Condition Code: The code remains unchanged. 


Program Interruptions: 


Privileged operation 
Protection (fetch violation) 
Addressing 

Specification 


Programming Note: When issued in extended mode, 
this instruction no longer sets the system mask as 
defined in the IBM System/360 Principles of 
Operation manual because bits 0-7 of the current 
PSW are redefined as follows: 

0-3 Spare (must be 0s) 

4 24-32 bit addressing mode 

5 Translation control bit 

6 I/O system mask 

7 External mask 

The individual channel mask bits must be set 
with the 'load multiple control' instruction. 


New Instructions 


Five new instructions are provided by the 2067: 


Instruction Mnemonics Type —_ Exceptions Code 
Load Multiple Control LMC RS M,A,S,D,P — B8 
Store Multiple Control STMC RS M,P,A,5S BO 
Load Real Address LRA RX N,A,5S Bl 
Branch and Store BASR RR 0D 
Branch and Store BAS RX 4D 


A Addressing Exception 

D Data Exception 

M Privileged Operation Exception 
P Protection Exception 


S Specification Exception 


Privileged operation and specification exceptions 
cause instruction suppression. Addressing, data, 
and protection exceptions cause instruction termin- 
ation and leave the setting of the control registers un- 
predictable. 

LOAD MULTIPLE CONTROL and STORE MULTI- 
PLE CONTROL change and inspect the control regis- 
ters in the same manner as LOAD MULTIPLE and 
STORE MULTIPLE change and inspect the general 
registers. Up to 16 32-bit registers may be pro- 
vided; unassigned control registers and unassigned 
bits within registers are stored as 0s and are ignored 
when loaded. These instructions use the RS format. 


The storage address must be located on a word bound- 
ary (i.e., the two low-order bits of the address must 
be 0) or a specification exception is recognized. 

LOAD MULTIPLE CONTROL and STORE MULTI- 
PLE CONTROL are privileged operations. 


Load Multiple Control Instruction 


LMC Ry, Rg, Dp (Bo) [RS] 


Eat ae 


0 78 1112 #415 16 19 20 31 


The set of control registers starting with the register 
specified by R, and ending with the register specified 
by R, is loaded from the locations designated by the 
second operand address. 

The storage area from which the contents of the 
control registers are obtained starts at the location 
designated by the second operand address and contin- 
ues through as many words as needed. The control 
registers are loaded in the ascending order of their 
addresses, starting with the register specified by 
R, and continuing up to and including the register 
specified by Ry; with register 0 following register 
15. The second operand remains unchanged. 


Condition Code: The code remains unchanged. 


Program Interruptions; 


Protection (fetch violation) 
Addressing 

Specification 

Data 

Privileged operation 


Programming Note: All combinations of register 
addresses specified by R, and Rey are valid. 
When the register addresses are equal, only 
one word is transmitted. When the address 
specified by R, is less than the address specified 
by R,, the register addresses wrap around from 
15 to 0. 


Store Multiple Control Instruction 


STMC Rye Ry. Dd, (B.) [RS] 


0 78 1112 #15 16 19 20 31 


The set of control registers starting with the register 
specified by Ry and ending with the register specified 


by R, is stored at the locations designated by the 
second operand address. 

The storage area where the contents of the control 
registers are placed starts at the location designated 
by the second operand address and continues through 
as many words as needed. The control registers are 
stored in the ascending order of their addresses, 
starting with the register specified by R. and contin- 
uing up to and including the register spedified by Re. ’ 
with register 0 following register 15. The contents of 
the control registers are unchanged. 


Condition Code: The code remains unchanged. 


Program Interruptions: 
Protection (store violation) 


Addressing 
Specification 
Privileged operation 


Load Real Address Instruction 


LRA Ry, Dy (Xp, By) [RX] 


0 78 1112 15 16 19 20 3] 








For 24-bit addressing the translated address of the 
second operand is inserted in the 24 low-order 
bits of the general register specified by R,.- The 
remaining bits of the general register are made 0. 

The address specified by the Xo, B,,; and D, 
fields is inserted in bits 8-31 of the general register 
specified by R,. Bits 0-7 are set to 0. The address 
is not inspected for protection or resolution. Address 
computation follows the rules for address arithmetic, 
Any carries beyond the 24th bit are ignored. 

For 32-bit addressing, the translated address 
of the second operand is inserted into the general 
register specified by R,. 

The address specified by the X,, B_, and Dy 
fields is inserted in the general register specified by 
R,. The address is not inspected for protection or 
resolution, Address computation follows the rules 
for address arithmetic, Any carries beyond the 32nd 
bit are ignored. Address translation takes place 
regardless of the status of the translation control bit. 


Resulting Condition Code: 


0 Translation was successful 

1 Translation unsuccessful (unavailability bit 
encountered in the segment table, or virtual 
address bits 0-7 > segment table register 
bits 0-7) 
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2 Translation unsuccessful (unavailability bit 
encountered in page table, or virtual address 
bits 12-19 > segment table entry bits 0-7) 

3 wasn 


When the resulting condition code is 1, the real 
address of the segment table entry is placed 

in the general register specified by Rj. When 
the resulting condition code is 2, the real address 
of the page table entry is placed in the general 
register specified by Ry. 


Program Interruptions: 
Addressing 


Specification 
Privileged operation 


Programming Note: The 'load real address' instruc- 
tion does not cause translation exceptions. 


Branch and Store Instruction 


BASR Ry Ry {RR} 
ore iia a 
0 78 1112 15 
BAS = Rj, Da, (Xp, Bo) = [ RX] 
oo [utele| om 
0 78 1112 1516 19 20 31 


The bits 32-63 of the PSW, including the updated 
instruction address, are stored as link information 

in the general register specified by R,. Subsequently, 
the instruction address is replaced by the branch 
address. If not in extended PSW mode or in 32-bit 
translate mode, bits 40-63 of the PSW are stored in 
the general register specified by R,. Bits 0-7 of 

the register specified by R; are made 0. In 32-bit 
translate mode, bits 32-63 of the PSW are stored 

in the general register specified by R,. 

The branch address is determined before the 
updated instruction address is stored. The instruction- 
length codes are 1 and 2 for the RR- and RX-format 
"branch and store’ instructions, respectively. 


Condition Code: The code remains unchanged. 


Program Interruptions: None 


Programming Note: The updated instruction address 
is stored without branching when in the RR format 
and the Ro field contains 0. 

When BRANCH AND STORE is the subject in- 
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struction of an 'execute' instruction, the instruction 
length code is 2. 


Arithmetic and Logical Functions 


The 2067 can perform the full range of arithmetic and 
logical functions described in the IBM System/360 
Principles of Operation manual. 

The CPU operates on a basic internal cycle time 
of 200 nanoseconds (nsec). Two major working 
arithmetic registers in the data path allow high speed 
and simplified implementation of the System/360 in- 
struction set. A 60-bit parallel adder facilitates 
handling of long fractions in floating-point operations. 
An 8-bit serial adder enables simultaneous execution 
of floating point exponent arithmetic, and also handles 
the decimal arithmetic and variable field length (VFL) 
instructions. 


Local Store 


Local store is a bank of 16 full-word, general-purpose 
registers and four doubleword floaing-point registers. 
All registers are implemented in transistor logic. 
They are used as index registers in address arithmetic 
and indexing, and as accumulators in fixed point, 
logical, and floating-point operations. 


IBM 2846 CHANNEL CONTROLLER 


The Channel Controller is used with a 2067-2 only. 
It provides the time sharing system with increased 
accessibility to auxiliary storage devices. Ina 
duplex configuration, it provides communication 
interface between the CPU's and the channels con- 
trolling auxiliary storage devices, It also provides 
paths for control information and data transfers be- 
tween the Processor Storage Unit and the channels. 
Relocation of these functions from the BCU of the 
2067-2 to the Channel Controller allows them to be 
used by both CPU's. 

The Channel Controller is contained in a single, 
stand-alone frame equipped with its own power supply. 
It contains a storage selection element (SSE), a pro- 
cessor interface element (PIE), and a scan/test 
element. The SSE provides the necessary controls 
and paths for data transfers between the attached 
I/O channels and the attached Processor Storage 
Units. The PIE provides a control path between the 
same I/O channels and attached CPU's. 

The Channel Controller can interface: 

1. Up to two 2067-2 CPU's. Additional 2846 attach- 
ment features must be added to each CPU that 
interfaces more than one Channel Controller. 

2. Up to eight 2365-12 Processor Storage Units; a 
2846 switching feature must be added to each 


Processor Storage Unit that interfaces a Channel 
Controller. An additional addressing feature 
must be added to each Channel Controller to 
permit the addressing of five to eight 2365-12s. 
_38. Up to seven physical channels (one 2870 Multi- 
plexer Channel and up to two 2860 Selector 
Channels, in any combination of models not 
exceeding cabling limitations). The addressing 
prefixing feature must be added to each channel. 
4, One 2167 Configuration Unit. 


Storage Selection Element 


The SSE provides the channels attached to the 2846 
with unique data and control paths to processor 
storage. A multiplex bus from the SSE to all Proces- 
sor Storage Units provides the path for storage ad- 
dressing and for I/O data. Simplex selection lines 

to each Processor Storage Unit communicate requests 
for storage references to the appropriate unit. The 
distribution of signals on these select storage lines is 
controlled by the set floating address switches on the 
2167. The assignment of address intervals to storage 
units directs the select storage signals as described 
in the 2067 section. The speed at which these requests 
are serviced depends on the availability of the addres- 
sed storage unit and the cable distance between the 
storage unit and the Channel Controller. 

Simultaneous requests to a Processor Storage 
Unit by multiple Channel Controllers are handled by 
the storage switching element on the storage unit. 

Each channel that needs a storage cycle sends a 
service request signal to the SSE. When not busy, 
the SSE continually scans for service requests. If 
only one channel requests service, that request is 
immediately recognized and processed; the SSE does 
not resume scanning until processing of the request 
is completed. If two or more channels request 
service, priority is granted in ascending channel 
number order (i.e. , channel 1 has the highest priority, 
then channel 2 on up to channel 6, followed by channel 
0). When the SSE finishes servicing a request, scan- 
ning resumes at channel 1. The high-speed I/O 
priority on channel 1 insures immediate servicing at 
the Channel Controller for the 2301 drum. 

The SSE examines the 12 high-order bits of the 
processor storage address for all 0s. If an all-zero 
condition exists and if prefixing is not inhibited, the 


SSE loads the 12 high-order position with the appropri-_ 


ate prefix. 
The prefix value is loaded into the address prior 
to decoding the set floating address switches. 


Processor Interface Element 


The PIE provides the communication link between the 
attached CPU's and channels. , 


The CPU/Channel Controller interface provides 
the operational lines used during normal program and 
interrupt operations of the channels. These lines in- 
clude the diagnostic lines used by the CPU to gain 
diagnostic control of a channel or of a Channel Con- 
troller, and the 'fault locating test' (FLT) lines re- 
quired to control a channel when a CPU is performing 
fault-locating tests. 

When two CPU's request access to the channel 
interface at the same time, CPU 1 has priority. 

During the selection sequence, the parity of the 
channel address and of the unit address is checked in 
the Channel Controller. If a parity error exists for 
the channel address, the Channel Controller will stack 
the check status, return a condition code 3 and release 
the CPU, thereby terminating the selection sequence. 
If a parity error is detected in the unit address, the 
Channel Controller stacks the check status and con- 
tinues with the selection sequence. 

_ If parity of both addresses is good, the Channel 
Controller determines which channel is requested by 
the CPU. The available line from that channel is then 
checked. If the channel is not available, the Channel 
Controller returns condition code 3 and releases the 
selecting CPU. If the channel is available, the selec- 
tion sequence is completed. The Channel Controller 
then waits for the selected CPU and the selected 
channel to finish the signaling sequence, and keeps 
the other CPU logically disconnected until this se- 
quence is completed. At completion, the Channel 
Controller disconnects the CPU and the channel, and 
resumes polling both CPU's for another access re- 
quest. 


Channel Interruption 


The Channel Controller receives, from the attached 
CPU's, the system mask bits associated with the 
attached channels (i.e. , Channel Controller 0 re- 
ceives mask bits 0-6 from control register 4, whereas 
Channel Controller 1 receives mask bits 8-14). Since 
each channel can be addressed by, and can interrupt, 
two CPU's, as many as two mask bits are received 
for each channel. Therefore, each I/O interrupt re- 
ceived by the Channel Controller from each attached 
channel can be gated to two CPU's. When a CPU has 
been interrupted, the Channel Controller provides 
that CPU with the address of the interrupting device 
and channel, 

The CPU places the device address and the channel 
address into its PSW and stores it at the old I/O PSW 
location. The Channel Controller then initiates another 
poll for CPU accesses to the channels. 
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Error Detection 


The Channel Controller monitors the CPU, channel, 
and storage interfaces and its internal circuitry for 
error conditions. When an error is detected, the 
Channel Controller causes an external machine check 
interrupt (if not masked off) at the CPU that initiated 
the operation during which the error is detected. 
When the interrupted CPU responds to the interrupt 
request, the error information is stored in the old 
machine-check PSW. 


IBM 2365 PROCESSOR STORAGE 


Model 67-1 systems use IBM 2365 Model 2 Processor 
Storage Units, and Model 67-2 systems use 2365 
Model 12 Processor Storage Units. Up to four 
2365-2s and eight 2365-12s can be used in the ap- 
propriate system configurations. 

Both models of the 2365 have a basic 750 nano- 
second storage cycle, and access eight bytes in 
parallel (a doubleword). A store function is possible 
on a byte basis, and any combination up to eight con- 
tiguous bytes can be stored in one storage cycle. 

Byte locations are consecutively numbered starting 
with 0. 

Each 2365 contains two independent storage 
arrays, each with its own address and storage 
buffer registers, Each array can access a double- 
word, and has 131,072 bytes of storage organized 
into 16,284 doublewords. All doublewords with odd- 
numbered addresses are in one array, and double- 
words with even addresses are in the other array. 

Four independent storage buses can be attached 
to the 2365-12: one from each CPU and Channel 
Controller in a full duplex system. The unit consists 
of two logical elements, called the Storage Switch 
Unit (SSU) and the storage element. 

‘The SSU contains appropriate priority circuitry, 
bus control circuits (partitioning), and a CE test and 
control panel. The SSU has independent power regula- 
tors, and derives primary power from an independent 
customer-supplied power source. 

The storage element contains the operational 
memory (two 128K byte arrays) common logic and 
independent power regulators. It derives its primary 
power from an independent customer-supplied power 
source. 


Priority 


The SSU determines priority for simultaneous storage 
requests as follows. The general rule is that Channel 
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Controllers have priority over CPU's. At installation 
time the relative priority between the two Channel 
Controllers and the relative priority between the two 
CPU's is established at each 2365-12. The Channel 
Controller that has first priority at one storage unit 
will not have it at every storage unit. The CPU 
priority also changes from storage unit to storage 
unit. 

At any given storage unit, the Channel Controller 
given first priority is that Channel Controller closest 
to the storage unit. The same is true of CPU relative 
priority. The Channel Controller priority also applies 
to its priority select signal. This arrangement mini- 
mizes the waiting time accumulated during simultan- 
eous selections, and improves overall system through-~ 
put. 

Another determinate in the establishment of 
priority for simultaneous selections is the odd-even 
criteria. The odd-even arrangement of doublewords 
into separate arrays permits overlapping of succes- 
sive storage accesses. Each CPU and Channel Con- 
troller provides two selection lines to the SSU for odd 
and even selection of doublewords. To overlap storage 
accesses, a Storage cycle on the array containing 
doublewords with odd-numbered addresses is over- 
lapped with the highest priority selection for access 
to the even array. For example, assume that (1) Chan- 
nel Controller 0 is using the odd array, (2) Channel 
Controller 1 selects odd, and (3) CPU-1 selects even; 
the storage cycle for CPU-1 will be overlapped with 
the last half of the access by Channel Controller 0. 
When Channel Controller 0 finishes with the odd array, 
Channel Controller 1 is given access. 

The SSU, upon receipt of a priority select signal, 
upgrades pending requests from that Channel Control- 
ler to the highest level of priority. 


Access Time 


The physical location of storage units with respect to 
CPU's contributes to variable storage access times. 
Access time for a doubleword from an adjacent stor- 
age unit is 750 nsec. This access time assumes no 
interference from other users of the storage unit. 

In duplex systems with multiple units accessing pro- 
cessor storage, the access time for a give cycle is 
dependent on cable distance between the user and the 
storage element, and on the degree of interference 
caused by simultaneous requests to storage from 
other users. In duplex systems storage cycles may 
be interleaved efficiently with alternate requests 
from the combined set of CPU's and Channel Con- 
trollers. The minimum interleaved access time 
possible is 375 nsec. 


Storage Protection 


The 2365-12 Processor Storage Unit contains a 
128-key storage protect array. Each key is com- 
posed of seven bits plus odd parity and protects 
2048 processor storage locations. 

Each protection key is established by a 'set key' 
instruction, When protection applies to a storage 
reference, the protection key is transmitted to 
storage; there, the contents of bits 1 through 4 are 
compared with the contents of the appropriate storage 
protect key. 

Bits 0-3 are the standard 4-bit protection keys. 
Bit 4 is the fetch-protection bit, bit 5 is the reference 
bit, and bit 6 is the change bit. The 4-bit protection 
keys in the PSW and CAW remain unchanged in length. 
The reference bit (bit 5) is set to 1 each time the cor- 
responding storage block is accessed for storing or 
fetching by a CPU or Channel Controller. The change 
bit (bit 6) is set to 1 each time data is stored in the 
corresponding storage block by a CPU or Channel 
Controller. 

Reference and change recording is always active. 
It is independent of: (1) the supervisor or masked 
state of the CPU, (2) the type of instruction or I/O 
command being executed, and (3) the manner in which 
the address is generated. Hence, references for up- 
dating or interruption purposes such as the timer, 
channel status word (CSW), or PSW locations are in- 
cluded in the reference and change recording. 

The reference and change bits are updated on all 
store or fetch references made to processor storage, 
even if one of the following conditions should occur: 

. Address parity check 
» Inkey parity 
. Out key parity check 
. Key mismatch 
. Cancel instruction 

In a 67-1 system, the 7-bit storage protect feature 
is required on each 2365-2 to provide the additional 
two bits for reference and change recording. This 
feature is not required on the 2365-12s in a Model 
67-2 system because 7-bit storage protect is pro- 
vided. 
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Partitioning 


The Configuration Unit provides a remote location for 
the 2365-12 partitioning switches. Each CPU and 
Channel Controller interface at the SSU is controlled 
by a unique switch. If communication between the 
SSU and a given CPU or Channel Controller is to be 
prevented, the selection signals are blocked at the 
SSU. The available line to the specific user is also 
disabled, making the storage element unavailable to 
that specific user. 


IBM 2167 CONFIGURATION UNIT 


The 2167 is a free-standing console which provides a 
central location for the switches required for parti- 
tioning and miscellaneous control functions. It is 
required in a Model 67-2. Manual switches for the 
following functions are located on the 2167: 

- Partitioning 

. Prefix activation 


. Direct control activation 

. Floating addressing -- Processor Storage Units 
. Floating addressing -- Channel Controllers 
The 2167 is available in three models: 
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Attachment Capability of 2067 Model 
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*1/O CU lists the number of dual-channel interface I/O control 
units that can be partitioned by switches on the 2167; i.e., 
2167 Models 1, 2, and 3 have 16 pairs of partitioning switches 

’ for I/O control units, and 2167 Model 4 has 32 pairs of [/O control 
unit partitioning switches. This is not necessarily a limitation on 
the number of [/O control units possible in a given configuration. 


Partitioning Switches 


A manual partitioning switch is provided on the 2167 
for each partitionable interface in the system. One 
switch is provided for each interface on a core stor- 
age unit, each CPU interface to a Channel Controller, 
and each channel interface on dual-channel interface 
I/O control units. Partitioning switches are located 
in the form of a matrix on the panel. The rows and 
columns of the matrix are identified with units. The 
switch controlling a given interface is located at the 
intersection of the column and row identified with the 
two units sharing the partitionable interface (Figure 7). 

The configuration status of all partitionable units 
is indicated by the contents of control registers 8 
through 14. When the system has been placed in a 
reconfigurable state (bit 9, control register 6), parti- 
tioning switches can be used to change the configura- 
tion status. 


Prefix Activation 


One switch to deactivate prefixing is provided per 
CPU. 
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Figure 7. Configuration Unit Control Panel 
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Direct Control Activation 


One switch per CPU is provided to deactivate the CPU 
extended direct control interface; WRITE DIRECT 
is not deactivated. 


Floating Addressing (2365-12) 


A rotary switch is provided for each 2365-12 in the 
system. The setting of this switch indicates the 
starting address of the address interval contained in 
that unit. (A starting address of 0 for the interval 
from 0 to 262,143; a starting address of 262,144 for 
the interval from 262,144 to 524,287, etc.). These 
switches are not interlocked to prevent assignment of 
the same starting address to more than one 2365-12. 


Floating Addressing (Channel) 


One rotary switch is provided for each CPU in the 
system. A switch can assign to the CPU with which 

it is associated either of two Channel Controllers 

(if Channel Controllers are in the system) for standard 
PSW mode operation. Switch assignment is overriden 
when the CPU is in extended PSW mode. 


Partitioning Sensing 


The capability for sensing the status of the manual 
switches by each CPU is provided in the Configuration 
Unit. The switch status is assembled into 32-bit 
words, which are accessible to the 'store multiple 
control' instruction, A 1-bit indicates that the switch 
is such that the corresponding interface is connected. 
A 0-bit indicates that the interface is disconnected. 
Parity is provided for each 8-bit byte of the 32-bit 
word. Each CPU senses the partitioning switches in- 
dependently. 


Control Register Bit Assignments for Sensing 


Of the 16 control registers that can be accessed by 
the 'load store multiple control' instructions, regis- 
ters 8 through 14 reflect, by bit, the manual switch 
settings. These registers can be stored into proces- 
sor storage, but cannot be loaded from processor 
storage. Table 5 identifies each register and the 
significance of each bit. 


Table 5. Control Register Bit Assignments 


1. 


Control Register 8: 


Bit Position* 


21 
22, 23 
24 
25 
26, 27 
28 
29 


30, 31 


Active Interface (Bit = 1) 
Processor Storage Unit 1 to CPU 1 
Processor Storage Unit 1 to CPU 2 
Unassigned 

Processor Storage Unit 1 to CC 0 
Processor Storage Unit 1 to CC 1 
Unassigned 

Processor Storage Unit 2 to CPU 1 
Processor Storage Unit 2 to CPU 2 
Unassigned 

Processor Storage Unit 2 to CC 0 
Processor Storage Unit 2 to CC 1 
Unassigned 

Processor Storage Unit 3 to CPU | 
Processor Storage Unit 3 to CPU 2 
Unassigned 

Processor Storage Unit 3 to CC 0 
Processor Storage Unit 3 to CC 1 
Unassigned 

Processor Storage Unit 4 to CPU 1 
Processor Storage Unif 4 to CPU 2 
Unassigned 

Processor Storage Unit 4 to CC 0 
Processor Storage Unit 4 to CC 1 


Unassigned 


*Bit equal to 1 for active interface. 
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Table 5. Control Register Bit Assignments (continued) 


2. Control! Register 9: 


32 


Bit Position* 


10, 11 


21 
22, 23 
24 
25 
26, 27 
28 
29 


30, 31 


Active Interface 

Processor Storage Unit 5 to CPU 1 
Processor Storage Unit 5 to CPU 2 
Unassigned 

Processor Storage Unit 5 to CC 0 
Processor Storage Unit 5 to CC 1 
Unassigned 

Processor Storage Unit 6 to CPU 1 
Processor Storage Unit 6 to CPU 2 
Unassigned 

Processor Storage Unit 6 to CC 0 
Processor Storage Unit 6 to CC 1 
Unassigned 

Processor Storage Unit 7 to CPU 1 
Processor Storage Unit 7 to CPU 2 
Unassigned 

Processor Storage Unit 7 to CC 0 
Processor Storage Unit 7 to CC 1 
Unassigned 

Processor Storage Unit 8 to CPU 1 
Processor Storage Unit 8 to CPU 2 
Unassigned 

Processor Storage Unit 8 to CC 0 
Processor Storage Unit 8 to CC 1 


Unassigned 


*Bit equal to | for active interface. 


. Assignments: 


Bit Positions 

0-3 

4-7 

8-11 
12-15 
16-19 
20-23 
24-27 


28-31 


Rotary Switch 
Setting 


1 


2 


Bit 


Codes 


0000 


0010 


0100 


0110 


1000 


1010 


1100 


1110 


Table 5. Control Register Bit Assignments (continued) 


3. Control Register 10: Processor storage address assignment codes. 


Starting Address Code for: 
Processor Storage Unit 1 
Processor Storage Unit 2 
Processor Storage Unit 3 
Processor Storage Unit 4 
Processor Storage Unit 5 
Processor Storage Unit 6 
Processor Storage Unit 7 


Processor Storage Unit 8 


b. Possible bit-code combinations for each 4-bit group: 


Set Floating 
Address Switch 


0 to 256K 

256K to 512K 
512K to 768K 
768K to 1024K 
1024K to 1280K 
1280K to 1536K 
1536K to 1792K 


1792K to 2048K 


Note: The 4-bit code stored by STORE MULTIPLE CONTROL 
represents address bits 11-14; j.e., bit 13 is on an address 
multiple of 256K bytes; thus, the 4-bit code represents the 
starting address of each unit. 


Table 5. Control Register Bit Assignments (continued) 


4. Control Register 11: 


Bit Position* 


21 


22-31 


Active Interface 
CC 0 to CPU 1 

CC 0 to CPU 2 
Unassigned 

cc 1 to CPU 1 

CC 1 to CPU 2 
Unassigned 

CPU 1 to only CC 0 
CPU 1 to only CC 1 
Unassigned 

CPU 2 to only CC 0 
CPU 2 to only CC 1 


Unassigned 


*Bit equal to | for active interface. 


See Note 


Note: Bit positions 16-31 set by channel controller compatibility 





switches. 


addressing switches; bit positions 0-15 set by partitioning 


5. Control Register 12 (I/O Control Unit Partitioning Sensing): 


Bit* /O Control Unit 
0, 1 1 
2,3 2 
4,5 3 
6,7 4 
8,9 5 
10, 11 6 
12, 13 7 
14, 15 8 


Bit* 1/O Control Unit 


16, 17 9 
18, 19 10 
20, 21 1 
22, 23 12 
24, 25 13 
26, 27 14 
28, 29 15 
30, 31 16 


*Bit equal to 1 for active interface. 


Note: For each control unit, the even-numbered bit defines 
the status of interface 1, the odd bit defines interface 2. 


Table 5. Control Register Bit Assignments (continued) 


6. Control Register 13: 


Bit* I/O Control Unit 
0, 1 17 
2,3 18 
4,5 19 
6,7 20 
8,9 21 
10, 11 22 
12, 13 23 
14, 15 24 


Bit* 
16, 17 
18, 19 
20, 21 
22, 23 
24, 25 
26, 27 
28, 29 


30, 31 


*Bit equal to I for active interface. 


//O Control Unit 
25 
26 
27 
28 
29 
30 
31 


32 


Note: For each control unit, the even-numbered bit defines 





7. Control Register 14: 
Bit Position* 

0-21 

22 

23 

24 

25 

26, 27 

28 

29 


30, 31 


the status of interface 1, the odd bit defines interface 2. 


Indication 


Unassigned 


2167 Power On 


Unassigned 


Direct Control, CPU 1 


Direct Control, CPU 2 


Unassigned 


Prefix, CPU 1 


Prefix, CPU 2 


Unassigned 


*Bit equal to 1 for active indication. 
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SYSTEM CONFIGURATION CHARACTERISTICS 


SYSTEM CONFIGURATIONS 


Three basic configurations are available: the Model 
67-1 for simplex applications, and the Model 67-2 
for half-duplex or duplex applications. 

Figure 8 shows the minimum simplex system 
configuration. The minimum configuration is repre- 
sented by solid blocks on the figure. Note that a 
2067-1 Processing Unit and 2365-2 Processor Storage 
Units are used. The Model 67-1 configuration is not 
expandable to a half-duplex or duplex system. How- 
ever, the minimum configuration can be expanded as 
shown by the dashed blocks on the figure, by adding 
two 2365-28, four additional selector channels, and 
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Figure 8. Model 67-1 Minimum Configuration 
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Max of 5 
Control Units 


three additional selector subchannels to the multi- 
plexer channel. Additional I/O control units and 
devices are not shown. However, each selector 
channel can attach up to eight I/O control units and 
address up to 256 I/O devices, the basic multiplexer 
channel can attach up to eight I/O control unit and 
address up to 192 I/O devices, and each selector 
subchannel can attach up to eight I/O control units 
and address up to 16 I/O devices. However, TSS/360 
supports magnetic tape and the 1052-7 attached to the 
2870 selector subchannel only. A single magnetic tape 
control unit can recognize all 16 device addresses, 
thereby excluding attachment of other control units 

to the selector subchannel for time sharing systems. 
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The minimum Model 67-2 half-duplex system is 
shown on Figure 9. Note that the 2067-2 Processing 
Unit, 2846 Channel Controllers, 2365-12 Processor 
Storage Units, and 2167 Configuration Units are used 
in Model 67-2 configurations. The half-duplex con- 
figuration can be expanded into a duplex system 
(Figure 10) by adding a second 2067-2 Processing 
Unit and a third 2365-12 Processor Storage Unit. 

The minimum configurations reflect the re- 
quirements of the program system (TSS/360). Each 
installation must expand this to fit the requirements 
of their facility. 


SYSTEM DATA FLOW 


Data is transmitted throughout the system along paths 
having number, width, and data-rate capabilities 
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Figure 9. Model 67-2 Half-Duplex System, Minimum Configuration 





Max of 5 
Control! Units 


that are designed for efficient information flow and 
for minimum interference. In general, paths are 
widest where data rates are highest. The number of 
paths between major elements of the system is a 
function of the requirement both for simultaneous 
operation and for availability. 

Data is transmitted eight bytes at a time between 
processor storage, the CPU's, and the channels, and 
is transmitted one byte at a time between the channels 
and I/O control units. Parity checking is performed 
throughout the system at the byte level. 

Figures 11 and 12 are data flow diagrams of a 
Model 67-1 and a Model 67-2 system respectively. 

A major difference between these systems is the 
storage BCU function. 

In a Model 67-2 system each CPU and each 
Channel Controller is connected, with separate bus, 
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to each storage unit in the system. For example, a and the attached channels. This path is eight bytes 





system with two CPU's and two Channel Controllers wide, including the associated parity bits. All data 
has four buses. Each bus can connect to as many as transfer between the BCU and the attached channels 
eight storage units. Conflicts that occur among the is accomplished over a single path; time sharing of 
several buses connected to each storage unit are re- the path is controlled by the BCU. The definition of 
solved at the storage unit. Channel Controller re- signals on this path (except signals required for 
quests for storage cycles are given priority over establishing priority among channels) is the same as 
CPU requests. Each CPU has a BCU that controls for signals on the storage bus. 
the storage bus with which the CPU is associated. 
The Channel Controller performs two types of tasks All communication between channels and I/O con- 
in the Model 67-2 data transfer function: it com- trol units is via I/O interface data buses (one in each 
municates with the storage units, and it serves the direction), which are one byte wide. The connection 
requests from its channels. In a Model 67-1 system, between channels and control units is standardized. 
both tasks are performed by the CPU BCU. Further information is given in IBM System/360 

The channel data path provides for the transfer Interface-Channel to Control, Unit Original Equipment 
of data between the Channel Controller or CPU BCU Manufacturers Information, Form A22-6843. 
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Figure 10. Model 67-2 Duplex System, Minimum Configuration 
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SYSTEM CONTROL PANEL 


The system control panel (Figure 13) contains the 
switches and indicators necessary to operate and 
control the system. Switches and indicators are also 
provided for operator intervention and for customer 
engineering operations. 

The operator control sections (sections G and C) 
are located in the lower and upper right portions of the 
system control panel. For monitor control operations, 
an identical control section can be provided on an IBM 
2150 Operator's Console. Operator control sections 
are the same throughout the System/360 line, providing 
operations with compatibility between machines, and 
are described in the IBM System/360 Principles of 
Operation manual. 

Operator intervention controls and indicators 
are located in sections E and F of the system control 
panel. These are described both in the IBM System/ 
360 Principles of Operation manual and in the follow- 
ing paragraphs. Appendix A is a summary of all 
system control panel controls and indicators. 


The customer engineer will use all controls and 
indicators; however, many of the controls and indica- 
tors located in sections A, B, E, and F are intended 
primarily for customer engineering use, and are not 
functionally described in this publication. 

By the use of the control panel, the operator can 
perform these important system functions: 

1. Reset the system. 

2. Store and display information in storage, in 
registers, and in the PSW. 

3. Load initial program information. 

These functions are described in the IBM System/360 


Principles of Operation manual. 


OPERATOR INTERVENTION CONTROLS 


Sections F and E of the system control panel contain 
the controls required for the operator to intervene 
in normal programmed system operations, These 
controls are intermixed with the customer engineering 
controls. Only operator intervention controls, on 
these panels, are described in this section. 

Operator intervention controls provide the system 
reset and the store and display functions. 


Start Pushbutton 
This pushbutton provides a means of starting the CPU 


in the process, instruction step, single-cycle, or 
single-cycle storage inhibit mode, depending on the 
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position of the rate switch. The operation is: 

1. If this switch is pressed after a normal halt, 
instruction processing continues as if no halt 
had occurred. Interruptions pending will be 
taken after execution of the first instruction. 

2. If this switch is pressed after an abnormal halt or 
system reset, the results will not necessarily be 
predictable. 

3. The type of operation executed by the start push- 
button depends on the position of the rate switch 
described later in this section. 


Stop Pushbutton 


This pushbutton provides the ability to completely 
terminate machine operations without destroying the 
machine environment. The operation is: 

1. The CPU proceeds to the end of the machine 
instruction being executed at the time the stop 
command is recognized. 

2. All waiting interruptions not masked off are 
executed. 

3. All I/O operations in process are allowed to be 
completed. 

4. The CPU is placed in the stopped state. 

5. The operator can continue normal program opera- 
tion by pressing the start pushbutton, or he can 
execute certain manual operations (e.g., an 
instruction-step operation). 


Rate Switch 


This rotary switch selects the rate that instructions 
are executed. It has four positions: PROCESS, INSN 
STEP (instruction step), SINGLE CYCLE, and SINGLE 
CYCLE STORAGE INHIBIT. 

Pressing the start pushbutton with the rate switch 
in the PROCESS position causes the system to operate 
at the normal clock speed of 200 nsec. 

With the rate switch set to the INSN STEP posi- 
tion, the system executes one complete machine in- 
struction for each depression of the start pushbutton. 
The high-resolution interval timer is disabled during 
instruction-step mode. The operation is: 

1. Any machine instruction can be executed in this 
mode. Interruptions are executed after the in- 
struction is completed. 

2. The stop point is identical to that achieved by the 
stop pushbutton. 

3. When I/O operations are started, they will be 
completed to the interruption point. 

4, The test light is on in the INSN STEP position. 
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With the rate switch set to the SINGLE CYCLE 
position, each depression of the start pushbutton 
advances the CPU one 200 ns machine cycle. The 
operation is: 

1. When the instruction being single cycled uses 
asynchronous devices, it single cycles through 
all CPU functions of the instruction to the initi- 
ation point of the asynchronous operation. The 
asynchronous operation starts on the next depres- 
sion of the start pushbutton and runs to the com- 
pletion point in a normal mamer. 

2. Ifthe asynchronous device initiates an interruption 
request during a single cycle operation, it is not 
automatically executed. The interruption is 
divided into single operations. More than one de- 
pression of the start pushbutton is required to 
complete the transfer of PSW's. 

3. During CPU storage cycles, more than one clock 
pulse is taken for each depression of the start 
pushbutton. 

4. The test light is on in the SINGLE CYCLE position. 

The SINGLE CYCLE INHIBIT position is for customer 

engineering functions. 


System Reset Pushbutton 


This pushbutton resets the on-line channels, control 
units, and CPU controls, including machine checks, 
to their initial state. The operation is: 

1. The pushbutton is active in all modes of operation. 
2. All check indicators are reset. 

3. The data flow registers are not reset. 

4, A system reset does not affect equipment in off- 
line channel operations. 

The CPU is placed in the stopped state. 

Since a system reset can occur in the middle of 
an operation, the contents of the PSW and of 
result registers and storage locations are un- 
predictable. 


oo 
ry ° 


Check Reset Pushbutton 


This pushbutton provides a means of resetting all 
check indicators in the CPU to the nonerror state. 
The operation is: 

1. Pressing the pushbutton resets all CPU check 
triggers and latches to the no-check state (it is 
a subset of the system reset pushbutton). 

2. This reset clears all CPU logic check indicators 
on the system control panel, 

3. Ifthe CPU is stopped because of a machine check, 
processing continues when the check indicators 
are reset. In this case, results are not pre- 
dictable. 
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Storage Select Switch (Section F) 


This toggle switch provides a means of selecting the 
storage unit that is to be addressed by the address keys 
when used with the display or the store pushbutton. 
The operation is: 

1. The MAIN position selects the main storage for 
addressing when storing or displaying. 

2. The LOCAL position selects the local store for 
addressing when storing or displaying. 

3. The MAIN BYTE position selects the main storage 
for addressing when storing or displaying, but 
causes only the byte addressed by the three low- 
order address keys to be stored. 


Address Switches (Section E) 


These 24 toggle switches provide a means of manually 
selecting an addressable location in storage. The 
operation is: 

1. The 24 switches are arranged in hexadecimal 
groups to permit storage addressing. 

2. Correct parity is generated automatically. 

38. Switches 2 through 20 are used with the address 
compare switch to select an address for an 
address compare stop or an address compare 
sync. 

4. Switches 0 through 11 are used for selection of 
ROS address and for a ROS compare sync. The 
sync pulse is provided whenever the ROS address 
compares successfully with the configuration 
placed in these switches. 


Data Switches (Section E) 


These 64 toggle switches provide a means of manually 

entering data into the location selected by the storage 

select switch and the address switches. The opera- 

tion is: 

1. The 64 switches are arranged in hexadecimal 
groups to permit data entry. 

2. Correct parity is generated automatically. 

3. Switches 53 through 63 are used as a count when 
the pulse mode count function is being performed. 


Store Pushbutton 


This pushbutton provides a means of storing informa- 

tion into any address in the storage specified by 

the storage select toggle switch. The operation is: 

1. The contents of the data switches are placed in 

the location specified by the address switches and 

and the storage select switch. 

Correct parity is generated automatically. 

3. If the storage select switch is in the MAIN posi- 
tion, the entire contents of the data keys are 
stored in the main storage. 


Re 


4, If the storage select switch is in the LOCAL 
position, the five low-order address switches 
specify the local store location in which the 
contents of the right half of the configuration in 
the data switches will be stored. Address switch 
19, when in the 0 position, permits storing in the 
general purpose registers; when in the 1 position, 
switch 19 permits storing into the floating point 
registers. The specific address is determined 
by the five low-order address switches. Address 
switches 19 and 20, when set to 1s, will address 
the working register (a local storage register 
not accessable under program control). 

5. If the storage select switch is in the MAIN BYTE 
position, the byte of data in the data switches 
specified by the three low-order bits of the 
address switches will be stored in main storage 
at the address specified by the address keys. 

6. The machine must be in a stopped state for this 
pushbutton to function. 


Display Pushbutton 


This pushbutton is pressed to display information in 
the location specified by the storage select switch 
and the address switches. The operation is: 

1. Ifthe storage select switch is in the MAIN BYTE 
position, the information in main storage at the 
address specified by the address switches is dis- 
played in the ST and AB registers. (See ''Roller 
Indicators.'') 

2. Ifthe storage select switch is in the LOCAL posi- 
tion, the information in the local store is dis- 
played in the T register. (See ''Roller Indica- 
tors.'') 

3. The machine muSt be in a stopped state for this 
pushbutton to function, 


Address Compare Switch 


This toggle switch provides a machine stop on a CPU 

storage compare. The operation is: 

1. In the center (normal) position, a synchronizing 
pulse (for CE use) is provided whenever the 
storage address bus compares successfully with 
bits 2 through 20 of the address keys. 

2. In the down (stop) position, the machine stops 
at the end of the instruction in progress when- 
ever the storage address bus compares success- 
fully with bits 2 through 20 of the address keys. 

3. The test light is on whenever this switch is in the 
down position. 


PSW Restart Pushbutton 


This pushbutton switch provides a method to restart 
programs by loading a new PSW from the contents of 


storage location 0. The operation is: 

1. With the machine in the stopped or reset state, 
pressing this pushbutton causes a new PSW to be 
fetched from storage location 0. 

2. The CPU continues processing after the new PSW 
is fetched if the rate switch is in the PROCESS 
position, 


Set IC Pushbutton (Instruction Counter) 


This pushbutton is pressed to enter an address into 
the instruction address of the current PSW. The 
operation is: 

1. This pushbutton sets bits 40-63 of the current 
PSW to the value specified in the address 
switches. The CPU is reset to the start of an 
I-fetch at that address. The instruction at the 
specified location is then fetched and loaded 
into the instruction buffer, and the instruction 
counter is updated. The machine then returns 
to the stopped state. 

2. The machine must be in the stopped state for 
this pushbutton to function. 


Note: The instruction address is displayed in 
the D register when the CPU is in the stopped state. 
(See ''Roller Indicators.) The new address con- 
tained in the instruction counter is one or two double- 
words more than the instruction address contained in 
the address switches. 


CPU Check Switch 


This toggle switch provides a means of controlling 
the system when a machine check is encountered. 
The operation is: 

1. With this switch in the PROC position, the CPU 
stops when a machine check is detected. Also, 
the machine status is logged to storage and an 
interrupt trap is initiated if the machine check 
mask in the PSWisal. If the machine check 
mask in the PSW is a 0, the check is ignored 
except that the check triggers are turned on. 

2. With this switch in the STOP position, the check 
triggers are set when a machine check is de- 
tected. The CPU stops and no log-out occurs. 
If the check reset pushbutton is pressed, the 
operation is resumed but the results are not 
predictable. 

3. With this switch in the DSAB position the check 
triggers are set when a machine check is de- 
tected. Log-out, interruption, and termination 
do not occur. The check triggers can be reset 
by pressing the check reset pushbutton or by a 
system reset. 

4, The test light is on whenever this switch is in the 
STOP or the DSAB position. 
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Log Out Pushbutton 


This pushbutton provides a means of logging the 

machine status into storage. The operation is: 

1. Pressing this pushbutton causes the machine 
status to be stored in fixed locations in main 
storage, 

2. This pushbutton is inactive under a normal 
processing condition. Log-out is the process of 
storing the status of most of the CPU indicators 
and registers in main storage. The log-out 
area occupies 44 words or 176 bytes of main 
storage, starting at byte 128. 


Stop On Storage Check Switch 


This switch provides a means of inhibiting storage 
accesses when a storage check occurs so that the 
indicators will not be changed. Storage checks re- 
sulting from accesses by channels and other proces- 
sors also cause a stop. The switchable indicators 
(rollers) are checked to determine the error and the 
address of the failing main storage word. 

This switch should be operated with the CPU 
check switch in the STOP position. The storage- 
stop state caused by a storage check is different than 
the stopped state. 

The test light is on whenever this switch is in the 
down position. 


Storage Indicate Switch (2067-1 Only) 


Information from a maximum of eight storage arrays 
(two 128K byte storage arrays per 2365) can be dis- 
played by the roller indicators. Depending on the 
setting of this switch, information from storage 
arrays 1 through 4 or from storage arrays 5 through 
8 is displayed. 


ROLLER INDICA TORS 
Section E contains six rows of 36 indicator lights. 


Above each row of lights is an opening, and behind 
each opening is a roller that can be positioned to 
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identify the significance of the related indicator lights 
for various operations. Each roller is manually 
placed in one of six positions by a positioning knob at 
the right side of panel B (see Figure 13). The signi- 
ficance of each roller position is identified by the 
printing on the face of the panel located beside the 
related positioning knob. 

In the display main storage operation, the contents 
of the addressed main storage locations are displayed 
in the ST and AB registers. For this operation, the 
ST register is identified on roller 1, position 3 and 
roller 2, position 3. The AB register is identified on 
roller 3, position 3 and roller 4, position 3. 

In the display local storage operation, the con- 
tents of the addressed register are displayed in the 
T register. The T register is identified on roller 2, 
position 3, 

When the CPU is in the wait or stopped state, all 
but two parts of the current PSW are identified on 
roller 4, position 1. The two exceptions are: (1) the 
instruction address, which is displayed in the D regis- 
ter (roller 1, position 2), and (2) the instruction length 
code (ILC), which is displayed in E register positions 
0 and 1 (roller 5, position 3). 


CUSTOMER ENGINEERING CONTROL 


The ROS (read-only storage) Transfer and Restart 
FLT I/O pushbuttons as well as all lever switches, 
except storage select, are principally for customer 
engineering use. All switches, lights and the meter 
in sections A and B are for customer engineering 
use only. 


KEY SWITCH AND METERS 


The usage meter and a customer engineering meter 
are installed in section F of the system control panel. 
A key switch controls the meter to be run when the 
machine is in process. When power is on and the key 
switch is in the customer operation position, the 
usage accumulates time. If the key switch is in the 
customer engineer position, the CE meter accumu- 
lates time. 


INTRODUCTION 


Two types of instruction times are presented in this 
section: (1) the average times for all instructions 
executed by the Model 67, and (2) the detailed times 
for all variable field length instructions executed by 
the Model 67. All symbols used to present Model 67 
instruction times are defined in the legends descrip- 
tion that precedes the instruction times. Standard 
System/360 instruction timing formula legends are 
used. 

Times are provided for instruction execution when 
instructions and data are located in main processor 
storage. All times are in microseconds unless other- 
wise noted. Complete information on each instruction 
is presented elsewhere in this publication or in the 


IBM System/360 Principles of Operation manual. 
Timing Considerations 


Unless otherwise noted, the following conditions were 
used in the development of instruction times in this 
section: 

1. The time required for indexing by a base register 
is included in the times given. For those instruc- 
tions that can be double indexed (indicated by one 
or two asterisks in the instruction column on the 
table for average instruction times), an additional 
0.15 us (one asterisk) or 0.2 us (two asterisks) 
must be added to the times given in the table. 

2. In all arithmetic operations, positive and nega- 
tive operands are equally probable. 

3. Each bit location has equal probability of con- 
taining bit values 0 or 1, and each bit location 
is independent of other bit locations. 

4. Addresses for unsuccessful branches are valid 
but unprotected storage locations. 

5. Decimal data can contain digit values 0-9 in each 
digit position with equal probability. When either 
the multiplier of a 'multiply decimal' instruction 
or a divisor of a 'divide decimal' instruction con- 
tains the digits 5 or 6 in each position, a slower 
than average instruction time (worst case) will 
result. An incremental decrease in instruction 
time is realized as the digits descend from 5 to 
0 or ascend from 6 to 9. 

6. Instructions may start on even or odd halfwords 
with equal probability. 

7. Interruptions are not reflected in these timings. 

8, All timings provided include both decoding and 
execution times for instructions. 


INSTRUCTION TIMES 


Timing Assumptions 


Unless otherwise noted, the following assumptions 
were used in the development of instruction times in 
this section: 

1. For the 'add decimal' (AP) and the 'subtract 
decimal' (SP) instructions, the first operand 
(i.e., the destination field) is assumed to be 
equal to or greater than the length of the second 
operand (i.e., the source field). 

2. Inthe 'edit and mark' (EDMK) instruction, an 
address is stored once; i.e., this instruction is 
used with a signal field, or a line with only one 
numeric field is employed rather than a complete 
print line. 

3. Inthe 'translate and test' (TRT) instruction, it is 
assumed that a nonzero byte from a translate and 
test table is found. 

4. The instruction times for floating-point instruc- 
tions depend on both the number of hexadecimal 
digits that are preshifted and postshifted, and on 
the number of times the result is recomplemented. 
The folating point instruction times given in this 
section are a weighted average of these variables. 

5. For the 'pack' (PACK), 'unpack' (UNPK), and 
‘move with offset' (MVO) instructions, itis 
assumed that no overflow field occurs. 

6. Instruction times for each format are modified as 
follows: 

a. 2067-1 

(1) RR -- Add 10 nsec for each instruction 
located in 3rd or 4th storage unit. 

(2) RX, RS, and SI -- Add 25 nsec for each 
instruction and 50 nsec for each operand 
located in 3rd or 4th storage unit. 

(3) SS -- Add 40 nsec for each instruction 
and 50 nsec for each operand located in 
3rd or 4th storage unit. 

b. 2067-2 

(1) RR -- For each instruction located in 

storage units 3-8, add one of the follow- 


ing: 

S3 - 10 nsec S6 - 40 nsec 
S4 - 25 nsec S7 - 50 nsec 
S85 - 25 nsec S8 - 60 nsec 


(2) RX, RS, and SI -- For each instruction 
located in storage units 3-8, add one 
of the following: 


S83. - 25 nsec S6 - 75 nsec 
S4 - 50nsec ST - 100 nsec 
S5 - 50nsec S8 - 125 nsec 
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(3) SS -- For each instruction located in 
storage units 3-8, add one of the follow- 


ing: 

S3 —~ 40 nsec S6 - 110 nsec 
S4 - 75 nsec S7 - 150 nsec 
S5 - 75 nsec S8 - 190 nsec 


(4) For each operand located in storage 
units 3-8, add one of the following: 


S3 - 50 nsec S6 - 150 nsec 
S4 - 100 nsec S7 - 200 nsec 
S85 - 100nsec S8 -—- 250 nsec 


(5) Additional delay due to dynamic address 
translation is identified in the 2067 
description in this publication. 

7. Instruction times for STM, STMC, LM, LMC, 
VFL Decimal, and Logical SS format instructions 
are modified as follows. When translation is 
indicated, the beginning and ending address of 
each field is tested by the translation process 
before instruction execution. Execution time is 
exposed to one of the following increments of 
additional time. 


Source of 
Translations Translated Additional Delay 
Per Field Address Per Field (nsec) 
1 Array 1850 
1 Lookup 2450 .+ 2 storage 
reference 
2 Array (2) 3050 
2 Array & 3650 + 2 storage 
Lookup references 
2 Lookup (2) 4250 + 4 storage 
references 
LEGENDS 


These legends are shorthand notations for data char- 
acteristics and computer conditions that were used to 
develop timing formulas for Model 67 instructions. 


Legends for Instructions with Multiple Timing For- 


mulas 


Legends A, to Ay are used for the 'store multiple’ 
or 'load multiple' instruction, depending upon quantity 
of general registers and position of doubleword bound- 
aries. 
Ay: Use if the number of registers is 2, and if the 
operand lies on doubleword boundaries. 


Ay: Use if the number of registers is > 2 and 
even, and if the operand lies on doubleword 
boundaries. 

Ag: Use if the number of registers is even, and 
if the operand does not lie on doubleword 
boundaries. 

A,: Use if the number of registers is odd. 
Legends E, and Es are used for the 'execute' instruc- 
tion. 

E5: Use when subject instruction is successful 

branch. 

E,: Use when subject instruction is not a success- 
ful branch. 

Legends V_ or Vg are used for 'move' instructions, 
depending upon the location of operand fields. 

V,: Use if first and second operand fields start 
and end on doubleword boundaries. 

Vo: Use if first and second operand fields start 

- at corresponding byte addresses within 
doublewords but do not lie on doubleword 
boundaries. 

Vg: Use if first and second operand fields do not 
start at corresponding byte addresses within 
doublewords or if N < 8, 

V5: Use if N, < No 

Vg: Use if N; > No 


Note: A byte address of a doubleword can have 
the value 0, 1, 2, 3, 4, 5, 6, or 7. A doubleword 
(8 bytes) must have an address that is a multiple of 
the number 8, but the four low-order bits of the 
binary address of a byte within a doubleword can 
have any value from 0 to 7. 


Legends for Instructions with Single Timing Formulas 
B = _ Total number of bytes of the first 

operand which are processed. It 

applies to instructions with a single 

length field. 

Time for the subject instruction which 

is executed by the 'execute' instruction, 

External delay. 

1 if the branch operation is successful, 

= 0 otherwise. 

1 if an overflow interruption occurs 

(PSW bit 36 = 1) or fixed point divide 

interruption occurs, 

0 otherwise. 

Ge = 0 if operand to be converted is positive, 

1 otherwise. 


ry 
a 
I 


Qa 
pay 
iH) 


GR = Number of general registers loaded or 
stored. 

M = Greater of N, or N.. 

MK = Number of times the mark address is 


stored in the 'edit' and 'mark' instruc- 
tion. 


Ng = 


NWBB 1 


Total number of bytes in the first oper- 
and for those instructions with a single 
length field. 
Total number of bytes in the first oper- 
and (destination). 
Total number of bytes in the second 
operand (source). 
Total number of bytes which overlap 
between the first and second operands. 
Ng = 0 for non-overlapping fields, or 
for overlapping fields where the address 
of the second operand is greater than or 
equal to the first operand address. 
Number of bytes of the field which lie 
outside of that part of the field bounded 
by doubleword. 
= Number of word boundary crossovers 
for that part of the first operand pro- 
cessed. 


NWBB, = Number of word boundary crossovers 


NWBL 


NWBL, 


for that part of the second operand 
processed, 

= Number of word boundary crossovers 
for the first operands. 

= Number of word boundary crossovers 
for the second operands. 


NWBL,L, = Number of word boundary crossovers 


qd, = 
QS = 
4 


8, = 


for that part of the first operand 
which consists of Ny bytes of high- 
order zeros, 
Quotient found by dividing by 4 the 
number of positions to be shifted. 
Smaller of N,- Sor N, - No. 


Remainder after dividing by 4 the number 
of position to be shifted. 

lifr, =3, orifq, = 0, 
2ifr,=3andq, = 0, 

0 otherwise. 


-1 iL ey 0, 
Lifry=1 and q, = 0, 
0 otherwise. 
Oifr, = 0 and qy # 0, 
1 if r, = 0andq, = 90, 


sifr, =1, 
5ifr, =2o0r 3. 
Oifr, = 0, 


4ifq, = 0 andr, = 1, or ifq, # 0 and 
t= 2. 

: a = 0 and r4 = 2, orif qd) # 0 and 
2ifq =Oandr, = 3, 

5 if a, # Oandr, =1. 

1 if the result field is recomplemented 
(i.e., changes sign), 

0 otherwise, 

1 if the result field is zero, 

0 otherwise. 

lifN, < 1/2 (N, +), 

0 otherwise. 

OifN, < 4, 

1 otherwise. 

0 if N, < 8, 

1 otherwise. 

0 if fields do not overlap, 

1 otherwise. 

0 if any non-zero function byte is found, 
1 otherwise. 

1 if Ry field of the 'execute' instruction 
is not zero, 

0 otherwise, 

Select out delay + device delay. 

Device delay for halt I/O sequence. 
Total number of doublewords in the first 
operand for those instructions with a 
single length field. 
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AVERAGE INSTRUCTION TIMES 


The average times for all instructions used by the 


Model 67 are as follows: 


Instruction 
Add 
Add* 


Add decimal 


Add double 

Add double* 

Add halfword* 

Add logical 

Add logical* 

Add normalized long 
Add normalized long* 
Add normalized short 
Add normalized short* 
Add unnormalized long 
Add unnormalized long* 
Add unnormalized short 
Add unnormalized short* 
AND 

AND* 

AND 


AND 


*Add 0.15 us when double indexed 
*kAdd 0.2 us when double indexed 
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Form 


RR 


Ss 


RR 


RR 


RR 


RR 


RR 


RR 


RR 


SI 


SS 


Mnemonic 


AR 


A 


AP 


ADDR 


ADD 


AH 


ALR 


AL 


ADR 


AD 


AER 


AE 


AWR 


AW 


AUR 


AU 


NR 


NI 


NC 


Model 67-1 
Times (us) 


0.65 


1.40 


3.4+0,2Mt+ 


0.2N,10. IN,t 


1 


T ,(2.0+0.4Ny) 


+1,2T, 
7.43 
8.20 
1.80 


0.65 


2.38 


2.81+0,5N+ 


0.2N, 


Model 67-2 
Times (us) 


0.69 
1.63 
3.52+0.2M+ 
0.2N,+0.1N,+ 
T1(2. 1540. 4N ) 
+1.35T, 


7.47 


8.43 


1.69 
2.63 
1.68 


2.61 


2.92+0.5N+ 


0.2N, 


Instruction 

Branch and link 
Branch and link** 
Branch and store 
Branch and store* 
Branch on condition 
Branch on condition** 
Branch on count 
Branch on count** 
Branch on index high 
Branch on index low or equal 
Compare 

Compare* 


Compare decimal 


Compare halfword* 
Compare logical 
Compare logical* 
Compare logical 
Compare logical 
Compare long 
Compare long* 
Compare short 
Compare short* 


Convert to binary* 


*Add 0.15 us when double indexed 
*kAdd 0.2 us when double indexed 


Form 


RR 


RR 


RR 


RR 


RS 


RS 


RR 


ss 


RR 


SI 
Ss 


RR 


Mnemonic 


BALR 


BAL 


BASR 


BAS 


BCR 


BC 


BCTR 


BCT 


BXH 


BXLE 


CR 


CP 


CH 


CLR 


CL 


CLI 


CLC 


CDR 


CD 


CER 


CE 


CVB 


Model 67-1 
Times (us) 


1.20 
1.20 
1.43 
1.40 
0.740.4F, 
0.8+0.3F 


1 
0.9840.17F | 
1.15 
1,6-0.2F | 
1.6-0.2F, 
0.65 

1.40 
3.47+0.2M+ 
0.13N +0. 1Np 
1.80 

0.65 

1.40 

1.40 
2.9+0.4B 
1.26 

2.00 

1.24 

1.98 
7.6+0.2G.,+ 


0.2G, 


Model 67-2 
Times (us) 


1.24 

1.43 

1.47 

1.63 
0.7440. 55F, 
0. Son S0 Es 
Is 0270.32F, 
1.38 
1.68-0. 05F, 
1.68-0. oF 
0.69 

1,63 
3.5910. 2M+ 


0.13N,+0.1N 


1 2 
2.03 

0.69 

1.63 

1.63 
3.0210.4B 
1,3 

2.23 

1.28 

2.21 


7.8370. 2G,+ 


0.2G, 
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Instruction 

Convert to decimal* 
Divide 

Divide* 


Divide decimal 


Divide long 
Divide long* 
Divide short 
Divide short* 


Edit 


Edit and mark 


Exclusive OR 
Exclusive OR* 
Exclusive OR 


Exclusive OR 


Execute* 


Halt I/O 


Halve long 


Halve short 


*Add 0.15 us when double indexed 
**kAdd 0.2 us when double indexed 


Form 


RR 


SS 


RR 


RR 


SS 


ss 


RR 


SI 


SS 


SI 
RR 


RR 


Mnemonic 


CVD 


DR 


D 


DP 


DDR 


DD 


DER 


DE 


ED 


EDMK 


XR 


XI 


XC 


EX 


HIO 


HDR 


HER 


Model 67-1 
Times (us) 


8.65+0.4G 
3 
8.4540. 15G, 
8.70+0.15G, 
5.95+4.5N 
e + e 
4.7N,+2.2N, 
- + 
(N,-Ng)+0.6T, 
+1,2T,Q8 
13.35 
14,10 
6.55 
7.30 
3.20+0.63N+ 
0.1N, 
3.20+0. 63N+ 


0. IN,*1. 2MK 


2.8+0.5Nt 


0.2N, 


E,=1.45tE 


E =2.6+E+0,4T 
6 12 


1. 4+U,tU, 


1.25 


1.05 


Model 67-2 
Times (us) 


8. 8840.46, 
8.49+0.15G, 
8.9340. 15G, 
6.07+4.5N4- 
4.7N,+2.2N, 
(N -N,)+0.6T, 
+1.35T,QS 
13.39 

14,33 

6.59 

7.53 

3.32+0. 63N+ 
0.1N, 

3.3240. 63N+ 
0.1N,+1.35MK 
1.29 

2.23 

1.96 

2.92+0. 5N+ 
0.2N, 
E,=1.68+E 


=2, 83+E+0. 
E,=2.83+E+0.4T 


.63+U_+ 
1.63+U,+U, 


Model 67-1 Model 67-2 


Instruction Form Mnemonic Times (us) _ Times (us) 
Insert character* RX Ic 1.40 1.63 
Insert storage key RR ISK 2.85 3.19 
Load RR LR 0.65 0.69 
Load * RX L 1.20 1,43 
Load address* RX LA 0.90 1.13 
Load and test RR LTR 0.65 0.69 
Load and test long RR LTDR 1.05 1.09 
Load and test short RR LTER 0.85 0.89 
Load complement RR LCR 0.65 0.69 
Load complement long RR LCDR 1,05 1.09 
Load complement short RR LCER 0.85 0.89 
Load halfword* RX LH 1.40 1.63 
Load long RR LDR 1.05. 1.09 
Load long* RX LD 1.40 1.63 
Load multiple RS LM A,=1. 40 A,=l. 63 


A,=0. 8+0.3GR Ay=0. 88+0.38GR 


Ag=1.210.3GR Ag=1. 2810. 38GR 


A,4=1.0+0.3GR A ,=1. 0840. 38GR 


Load multiple control RS LMC 1.6+1.4GR 1,68+1.48GR 
Load negative RR LNR 0.95 0.99 
Load negative long RR LNDR 1,05 1.09 
Load negative short RR LNER 0.85 0.89 
Load positive RR LPR 0.95 0.99 
Load positive long RR LPDR 1.05 1.09 
Load positive short RR LPER 0.85 0.89 


*Add 0.15 us when double indexed 
*kAdd 0.2 us when double indexed 


Instruction Times 


Instruction 

Load PSW 

Load real address 
Load short 

Load short* 

Move 


Move 


Move numerics 


Move with offset 


Move zones 


Multiply 
Multiply* 


Multiply decimal 


Multiply double 
Multiply double* 
Multiply halfword* 
Multiply long 


Multiply long* 


*Add 0.15 us when double indexed 
*kAdd 0.2 us when double indexed 
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Form 


SI 


RR 


SI 


SS 


SS 


SS 


SS 


RR 


SS 


RR 


RR 


Model 67-1 


Mnemonic Times (us) 


SPSW 


LRA 


LER 


LE 


MVI 


MVC 


MVN 


MVO 


MVZ 


MR 


MP 


MDDR 


MDD 


MH 


MDR 


MD 


2.20 
2.3 

0.65 
1.20 
1.33 


V,=2. 011, 4W 


1 
V2=3.140.2N+0.2N¢ 
V9=2.9340, 38N+0, aN, 
2.8t0.5Nt+ 

0. 2Ne, 
2% 9310.27N + 
0.3N5+0.4N,,, 
2.810.5Nt 
0.2N, 
4,45 

4.80 

3. lit3, 4N, - 


2.9N,+1. ONo 


(Nq-Np) 
10.03 
10.8 
5.00 
7.25 


7.60 


Model 67-2 
Times (us) 


2.43 


2.93 


V 1=2.42+1.55W 
V,=3.22+0.2N+0,2N, 


V3=3. 05+0. 38N+0.2N, 


2.92+0.5Nt+ 
0.2N3 


3.05+0, 27N,t 


0.3N,+0.4Ng, 


2, 
if N, > N; 
2.92+0.5N+ 
0.2N, 
4,49 

5.03 

3. 8913. 4N, - 
2.9N,+1.0N, 


(N,-Ny) 
10.07 
11.03 
5.23 
7,29 


7,83 


Instruction 
Multiply short 
Multiply short* 
OR 

OR* 


OR 


OR 


Pack 


Read direct 

Set program mask 

Set storage key 

Set system mask 

Shift left double 

Shift left double logical 
Shift left single 

Shift left single logical 


Shift right double 


Shift right double logical 


*Add 0.15 us when double indexed 
*kAdd 0.2 us when double indexed 


Form 


RR 


RR 


SI 


SS 


SS 


SI 


RR 


RR 


SI 


RS 


RS 


RS 


RS 


RS 


RS 


Mnemonic Times (us) 
MER 4.05 
ME 4.40 
OR 1.25 
O 2.00 
OI 1.73 
Oc 2.8+0.5N+ 
0.2N, 
PACK 2.8740. 27N + 
N+1 
0.2N,, if N, > _2 
2 
RDD 2.70+ED 
SPM 0.85 
SSK 1.8 
SSM 4.16 
SLDA 0.940. 4q4+ 
0.28, 
SLDL 0.940. 4q ,+ 
0.28, 
SLA 0.740.2q + 
0.28, 
SLL 0.740. 2q + 
0.28, 
SRDA 0.940.4q + 
0.28, 
SRDL 0.940. 4q,, + 
0.28, 


Model 67-1 


Model 67-2 
Times (us) 


4,09 


2.92+0.5N+ 
0.2N3 


2. 99+0.27N + 


; N +1 

0.2N,, if N, > 2 
2.93+ED 
0.89 
2.14 
4.54 
0.9840, 4q + 
0.25, 
0.9840. 4q, 
0.25, 
0.7810. 2q,t 
0.28, 
0.7840. 2q 7 
0.25 

1 
0.9840. 4q + 
0.28 

4 
a Vi 


0.28 
4 


Instruction Times si 


Instruction 


Shift right single 


Shift right single logical 


Start I/O 

Store* 

Store character* 
Store halfword* 
Store long* 


Store multiple 


Store multiple control 
Store short * 

Subtract 

Subtract* 


Subtract decimal 


Subtract double 
Subtract double* 
Subtract halfword* 


Subtract logical 


*Add 0.15 us when double indexed 
**kAdd 0.2 us when double indexed 
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Form _ 


RS 


RS 


SI 


RS 


RS 


RR 


SS 


RR 


RR 


Mnemonic 


SRA 


SRL 


SIO 


ST 


STC 


STH 


STD 


STM 


STM 


STE 


SR 


SP 


SDDR 


SDD 


SH 


SLR 


Model 67-1 
Times (us) 


0.940. 2q, + 
0.28, 
0.940. 2q + 
0.28, 
1.4040, 

0.93 

133 

1.73 

0.93 

A =1.38 
A,=0.53+0,2GR 
A,=1.33+0.2GR 
A ,=0.93+0,2GR 
1.0+1.4GR 
0.93 

0.65 

1.40 

3.440. 2M+ 

0.2N +0. INyt 
T (2.040. 4Ny) 
+127, 


7.43 


8.20 


Model 67-2 
Times (us) 


. 9840. 2q + 
0. 98+0. 2q, 
0.28 

2 
0.9840. 2q,+ 
0.28, 


1.63+U 
1 


1.16 
A_=1.56 

1 
A,=0.6110,28GR 
Ag=1.41+0.28GR 
A ,=1.01+0,28GR 
1.0841, 46GR 


1.16 


3,52+0.2M+ 


0.2N 


1°9- INS? 


T, (2. 15+0.4N,) 
+1.35T> 


7.47 


Instruction 

Subtract logical* 

Subtract normalized long 
Subtract normalized long* 
Subtract normalized short 
Subtract normalized short* 
Subtract unnormalized long 
Subtract unnormalized long * 
Subtract unnormalized short 
Subtract unnormalized short* 
Supervisor call 

Test and set 

Test channel 

Test I/O 

Test under mask 

Translate 


Translate and test 


Unpack 


Write direct 


Zero and add 


*Add 0.15 us when double indexed 
*xkAdd 0.2 us when double indexed 


RR 


RR 


RR 


RR 


SI 


SI 


SI 


SI 


SS 


SS 


SS 


SI 


SS 


Mnemonic 


SL 


SDR 


SD 


SER 


SE 


SUR 


SU 


SVC 


TS 


TCH 


TIO 


TM 


TR 


TRT 


UNPK 


WRD 


ZAP 


Model 67-1 
Times (us) 


1.40 
1.72 
2.45 
1.68 
2.43 
1.65 


2.40 


1.80 


1.40+ 
4 U, 


1.40+U, 
1.60 
1.94+1.78N 
4,141. 2B- 


1.0T 
9 


2.8+0.4N,+ 


0. 1N,70. 2T3, 


Nt+1 Mm N 


z 


if 2 


2.2 
3.5010.2Mt 


0.1N,10. IN, 


+0,72T +1.2T 
8 2 


Model 67-2 
Times (us) 


1.63 


1.76 


1.72 
2.66 
1.69 


2.63 


2.03 
1,63+U, 
1.63+U, 
1. 83 
2.0641. 78N 
4,22+1,.2B- 
1.0T 
9 
2.92+0. ea Ga 
0.1N_ +0.2T., 
2 3 


+ 
¢ Nyt N 


i > 2 
2 


2.43 
3.62+0.2Mt+ 


e +0, 
0 IN, 0 IN, 


+0.72T,t1. soT,, 


8 
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DETAILED INSTRUCTION TIMES (VARIABLE FIELD 
LENGTH INSTRUCTIONS) 


The following timing formulas are for VFL instruc- 
tions (i.e. , those instructions that contain an "L" 
field). All times are given in terms of the word bound- 
ary crossovers and the operand addresses. The term 
"word boundary" specifies the boundary between two 
physical words. A physical word is the amount of 
information fetched in a single storage cycle (this is 

64 bits for all Model 67s). Thus, the number of word 
boundary crossovers is one less than the number of 
doublewords spanned by the field. 


Timing Formulas for VFL Instructions (Model 67-1) 


Instruction Mnemonic Formula 

Add decimal AP 3.75+0.2M+1.6NWBL,+0. 8NWBLotT, 
(2.2+2Nj+1. 6NWBL,)+1.2T, 

AND NC 3.16+0,2N+1.6NWBL,10. 8NWBL,*0. 2N5 

Compare decimal CP 3.75+0.2M+1. OONWBL, +0. sNWBL, 

Compare logical CLC 3.16+0.2B+0. 8NWBB 179- 8NWBB, 


Note: The compare logical operation is terminated 
when an unequal condition is found. 


Divide decimal DP 6.244, 4N,-4, 8Not2. 20N>(N,-No)+0. 8NWBL,+ 
0. 8NWBL,10. 6T etl. 2T QS 
Edit ED 3.5710. 43N11.6NWBL 10. 8NWBLo 
Edit and mark EDMK 3.5610,43N71. 6NWBL,T1. 2NWBL +1. 2MK 
Exclusive OR XC 3.16+0.2N+1,6NWBL1+0. 8NWBLo+0. 2N. 
Move characters MVC V i724. 0+1.4W 
Vo=3- 36+0. SNWBL,T+0. 8NWBL,+0. 2Ne 
V3=38. 16+0. GNWBL, 0: 8NWBL,t0. 2N,10. 2N 
Move numerics MVN 3.16+0.2Nt1, 6NWBL, +0. 8NWBL, +0. 2Ne 
Move with offset MVvO 


54 


V.=3. 2+0, aN 70. 6NWBL vo 8NWBL,10. AN, 


=3,2+0.4N_+0.2(N.-N,)+0. +0. +0, 
V,=3 4N,+0.2(N-N,)+0. 6NWBL +0. 8NWBL,+ 0. 4N, 


Instruction Mnemonic Formula 


Move zones MVZ 3.16+0,2Nt1. ew ee 8NWBL+0. 2N, 

Multiply decimal MP 4,1213,4N,-3. 2N,+1. ONA(N,-N,)70. 8NWBL,+1.6NWBL Lo 
OR OC 3.16+0.2N+1.6NWBL,+0. 8NWBL9+0. 2N, 

Pack PACK 3.1140.2N,+0, 1N>+0. 6(NWBL,1t0. 8NWBL, 

Subtract decimal SP 3.75+0.2M+1.6NWBL +0. 8NWBLotT,(2.240. 6NWBL,)+1. 2T> 
Translate TR 2.4+1,6Nt1. 4NWBL, 

Translate and test TRT 3.641. 0N+1. 8NWBB -1. OT 9 

Unpack UNPK 3.16+0.2N,11. 6NWBL, 11. 6NWBL,+0. 2T., 

Zero and add ZAP 3.75+0.2M+0, 8NWBL, 10. 8NWBL,*0. 727.41. 2T, 


Timing Formulas For VFL Instructions (Model 67-2) 


Instruction Mnemonic Formula 

Add decimal AP 3.8710.2M+1. 75NWBL, 10. 95NWBL, tT) (2. 2+2N + 
1.75NWBL,)t1. 35T, 

AND NC 3.28+0.2N+1.75NWBL, +0. 95NWBL,+0.2N, 

Compare decimal CP 3.87+0.2M+1. 15NWBL jee 95NWBL, 

Compare logical CLC 3.2810.2B+0. 95NWBB,+0. ISNWBBo 


Note: The compare logical operation is terminated 
when an unequal condition is found. 


Divide decimal DP 6. 32+4,4N)-4. 8N, +2. 20No9(N,-No)t0. SONWBL 0. 95NWBI, 
+0, 6T tH. 2T,QS 

Edit ED 3.69+0.43Nt1.75NWBL, +0. ISNWBLo 

Edit and mark EDMK 3.68+0,43Nt1, 75NWBL+1.35NWBLo+1.2MK 

Exclusive OR XC 3.2810.2Nt1. 75NWBL 0. 25NWBLo51t0. 2Ng 

Move characters MVC V + 2.4241. 55W 
Vo= 3.4840. 9SNWBL, +0. 96NWBLot0. 2Ne 


V.= 3.2810, TONWBL, +0. 95NWBL,*0. 2N,10. 2N 


Move numerics MVN 3.28+0.2Nt1, 75NWBL, +0. 9S5NWBLo 10. 2N3 


1 
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Instruction 


Move with offset 


Move zones 


Multiply decimal 


OR 
Pack 


Subtract decimal 


Translate 


Translate and test 


Unpack 


Zero and add 


56 


Mnemonic 


MVO 


MVZ 


MP 


OC 


PACK 


SP 


TR 


‘TRT 


UNPK 


ZAP 


Formula 


Ve= 3.32+0. aN TOs TSNWBL, +0. 9SNWBL,+t0 é 4N, 


veo 3.3210. 4N,t0. 2(N,-No)t0. 75NWBL,10. ISNWBLot 


0.4N5 


3.28+0.2Nt1. CSW ET 95NWBL, +0. 2N, 


4, 24+3.4N,-3. 2N, +1. ON,(Ny-No)t0. 95NWBL,+ 
1.75NWBL._L 
12 


3.28+0.2Nt1. Wa 95NWBL, +0. 2N, 


3.23+0.2N,+0. ae TSNWBL, +0. 95NWBL, 
3.87+0.2M+1.75NWBL,+0. 9SNWBL,+T (2. 2+0. TONWBL, )t 


1.35T 
2 


2.52+1.6N+1.55NWBL 1 
3.7241. 0Nt1. 95NWBB,-1. ae 


3. 28+0.2N +1. TSNWBL, +1. TO5NWBL,+0.2T3 


2 


3.87+0.2M+0. 9SNWBL,+0. 9SNWBL,10. 72T,1+1. 35T 


1 8 2 


APPENDIX A. SUMMARY OF SYSTEM CONTROL PANEL CONTROLS AND INDICATORS 


Panel Switch/Indicator Name 
A All 
B All 
Cc EMERGENCY PULL 
D sim 
E Roller Switches and Indicators 
E DATA 0-31, DATA 32-63 
E ADDRESS 
E STOR CHK 
E PROC CHK 
F TEST MODE 
REPEAT 
ROS-PROC-FLT 
F ARRAYS INDICATE 
F FREQUENCY ALTERATION 
F DEFEAT INTERLEAVING 
F STOP ON STORAGE CHECK 
F DISABLE INTERVAL TIMER 
F STORAGE SELECT 
MAIN 
LOCAL 
MAIN BYTE 
*Abbreviations: 


IND - Indicator 

PB ~ Pushbutton Switch 
PS - Pull Switch 

RTY - Rotary Switch 
TGL - Toggle Switch 


TGL 


TGL 


IND 


IND 


TGL 


TGL 


TGL 


TGL 


TGL 


TGL 


TGL 


TGL 


Function 


For customer engineering use. 

For customer engineering use. 

When pulled, this switch initiates emergency off in 
the system, 

For expansion. 

There are six 6-position roller switches and 36 in- 
dicators associated with each switch. The roller 
indicators are tested between positions of the switch. 
Position 6 of roller 6 is used to test the remaining 
indicators on the system control panel and on the 
2150 console. 

These 64 switches, in hexadecimal groups, permit 
manual entry of data. Correct parity is generated 
automatically. 

These 24 switches, in hexadecimal groups, select an 
addressable location in storage. Correct parity is 
generated automatically. 

Indicates an error in the storage units. 

Indicates an error in the CPU. 


For customer engineering use; should be in center 
position for normal CPU operation. 

For customer engineering use; the PROC position 
does not affect CPU operation, and is the normal 
position of this switch. 

Used on 2067-1 only. Selects the storage elements 
(1 through 4 or 5 through 8) that will have information 
displayed by roller switch indicators. 

For customer engineering use, and is effective only 
when the CE key switch is in the CE position. 

For customer engineering use; PROC is the normal 
position. 

For customer engineering use; should be in center 
position for normal operation. 

For customer engineering use; should be in center 
position for normal operation. 


Normal position; selects main storage for storing or 
displaying data. 

Selects local storage for storing or displaying data. 
Same as normal position except that the byte selected 
is the only byte affected by a manual store operation. 
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Panel Switch/Indicator Name 
F ADDRESS COMPARE STOP 
F CPU CHECK 
PROC 
DSAB 
STOP 
F PULSE MODE 
F REPEAT INSN 
F REPEAT ROS ADDRESS 
F RATE 
INSN STEP 
PROCESS 


SINGLE CYCLE 


SINGLE CYCLE STORAGE 


INHIBIT 
¥ SYSTEM RESET 
F CHECK RESET 
F PSW RESTART 
F ROS TRANSFER 
F SET IC 
F STORE 
F DISPLAY 
F START 
F STOP 
F RESTART FLT I/O 
F LOG OUT 


*A bbreviations: 
IND - Indicator 
PB - Pushbutton Switch 
PS - Pull Switch 
RTY - Rotary Switch 
TGL ~ Toggle Switch 
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Type* 


TGL 


TGL 


TGL 
TGL 
TGL 


RTY 


PB 


PB 
PB 


PB 
PB 


PB 
PB 
PB 
PB 


PB 
PB 


Function 


Stops processing when the storage address agrees 
with bits 2 through 20 of the address switches. Should 
be in center position for normal operation. 


This is the normal position. If the PSW machine 
mask is a 1, the CPU stops on detection of a CPU 
check and the status is lagged into main storage. 
If the mask is 0, the result is the same as if the 
switch is in the DSAB position. 

The CPU does not stop on detection of a machine 
check, but the check trigger is set. 

The CPU stops on detection of a machine check, 
but there is no log-in of data. 

For customer engineering use; should be in PROC 
position for normal CPU operation. 

For customer engineering use; should be in PROC 
position for normal CPU operations. 

For customer engineering use; should be in center 
position for normal operation. 


CPU executes one machine instruction for each 
depression of the start pushbutton. 

Does not affect CPU operation; CPU operates at 
normal clock speed. 

CPU advances by minimum clock amount for each 
depression of the start pushbutton; all CPU opera- 
tions are as in PROC position. 

Same as SINGLE CYCLE position without storage 
references. 

Resets on-line channels, control units, and CPU con- 
trols (including machine checks) to their initial state. 
Resets all CPU and storage check triggers. 

Loads a PSW from main storage address zero and 
starts processing. 

For customer engineering use. 

Enters an address from address switches into the 
active (current) PSW. 

Enters data into the storage location specified by the 
storage select switch and the address switches. 
Displays data specified by the storage select switch 
and the address switches. 

Starts the CPU operating in the mode selected by the 
rate switch. 

Terminates CPU operation without changing the 
environment. 

For customer engineering use. 

Stores CPU status in fixed locations in main storage. 


Panel Switch/Indicator Name 
F Elapsed Time Meters 
F Key Switch 

G POWER ON 

G PREFIX SELECT 

G POWER OFF 

G LOAD UNIT 

G INTERRUPT 

G LOAD 

G SYSTEM 

G MANUAL 

G WAIT 

G TEST 

G LOAD 

*A bbreviations: 


IND ~ Indicator 

PB - Pushbutton Switch 
PS - Pull Switch 

RTY - Rotary Switch 
TGL - Toggle Switch 


Type* 


PB/IND 


TGL 


RTY 
PB 


PB 

IND 
IND 
IND 
IND 


IND 


Function 


Indicate CPU running time. The process meter 
shows customer elapsed time; the CE meter shows 
customer engineering elapsed time. 

Determines which elapsed time meter will be used to 
record time. 

Initiates power on in the CPU and in selected system 
units. It is backlighted. 

Selects either main or alternate prefix during 
manually-initiated program loading. 

Initiates power off in the CPU and in selected system 
units, 

These three switches select the I/O units used by a 
load operation. 

Causes an external interruption in the system and 
sets bit 25 of the interruption code to a 1. 

Resets the system and starts a load operation. 
Indicates a CPU elapsed time meter is running. 
Indicates that the CPU as in the stopped state. 
Indicates that the CPU is in the wait state. 

Indicates that a switch on panel F is not in the nor- 
mal operating position or that a channel is in the 
test mode. 

Indicates that a CPU load operation is in progress. 
A successful load turns off the indicator. 
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GLOSSARY 


Address Translation. The process of replacing the 
12 high-order bits (24-bit addressing) of a virtual 
address with 12 bits of a physical address. For 32- 
bit addressing situations, the 20 high-order virtual 
address bits are replaced. 


Associative Array. An array of eight associative 
storage registers used in the dynamic address trans- 
lation process, Each register contains both a virtual 
address and its equivalent current physical address. 


Bus Control Unit. The logic used to control the flow 
of information over the several buses attached to pro- 
cessor storage. The BCU controls the address buses 
as well as the data buses to and from storage. Pri- 
ority determinations in the use of the buses and assoc- 
iated control signals are handled by the BCU. A BCU 
is used for channel and CPU communications with pro- 
cessor storage. 


Command, One or more upper-case alphabetic terms 
for which TSS/360 has a predetermined unique re- 
sponse, 


Command Language. The set of commands that are 
recognized by TSS/360 and result in a predetermined 
set of actions. 


Command System. The set of programs required to 
provide responses to commands. 


Conversation. Describes the interaction or dialog 
between a user and a time sharing system, via a 
terminal device, whereby the user can control, in- 
terrogate, modify, and observe the processing of 
his task. 


Data Management, A general description of the col- 
lective functions of a programming system that pro- 
vide access to data sets, enforce data storage con- 
ventions, and regulate the use of I/O devices. 


Data Set. A named collection of logically related 
data items, arranged in a prescribed manner, and 
described by control information to which the pro- 
gramming system has access. 


Direct-Access, A type of storage medium which 
allows information to be accessed by positioning the 
medium or accessing mechanism directly to the in- 
formation required, thus permitting direct addres- 
sing of data locations. 


60 


Dynamic Address Translation, Address translation 


that occurs at instruction execution time. 


Extended Direct Control. The direct control function 
as modified for IBM System/360 Model 67-2. The 
'read direct' instruction is dropped, performance of 
WRITE DIRECT has been modified, and some external 
signal lines have been assigned specific control func- 
tions. 


Extended Dynamic Address Translation, Dynamic 


address translation for 32-bit addresses. 


Extended PSW Mode. The CPU mode of operation in 
which some functions normally controlled by bits of 
the PSW are assigned to control registers, logically 
extending the PSW to include those control registers. 
The Extended PSW mode is controlled by bit 8 of con- 
trol register 6, . 


Extended Storage Protection. The 7-bit storage 
protection feature for IBM System/360 Model 67; in- 


cludes storage protection, fetch-protection, and two 
additional bits identified as reference (bit 5) and 
change (bit 6). Bit 5 of the protection key for the 
referenced block is set to 1; any store operation 
causes bit 6 to be set to 1. 


High Resolution Interval Timer, The timer feature 
used in IBM System/360 Model, 67; this timer has a 


resolution time of 13 usec. 


Language Processor. A general term for any assem- 
bler, compiler, or other routine that accepts state- 
ments in one language and produces equivalent state- 
ments in another language. 


Library. In general, a collection of objects (for 
example, data sets or volumes) associated with a 
particular use, and the location of which is identified 
in some type of directory. 


Linkage. The means by which communication is 
effected between two programs. 


Linkage Editor, A program that produces an object 
program module by transforming other program 
modules, optionally combining separate control 
sections into a single control section, resolving 
symbolic cross-references among them, replacing, 
deleting, and adding control sections on request. 


Load. The process of reading the beginning of a 
program into virtual storage and making necessary 
adjustments and/or modifications to the program so 
that it may have control transferred to it for the 
purpose of execution. 


Main Storage. Storage which is directly addressed 
by the registers of a central processing unit; hence, 
storage from which program instructions may be 
fetched and executed. 


Module (Programming). The input to, or output 


from, a single execution of an assembler, compiler, 
or linkage editor; a source or program module; 
hence, a program unit that is discrete and identifi- 
able with respect to compiling, combining with other 
units, and loading. 


Multiple Access. That characteristic of a system 
which allows many users to share the total system 
concurrently, each as if he has sole use of the sys- 
tem. 


Multiprocessing. The simultaneous use of two or 
more processing units in the same computing system. 


Object Program Module. The output of a single 
execution of an assembler, compiler, or link editor, 


which constitutes input to the dynamic loader or the 
linkage editor; an object module consists of one or 
more control sections in relocatable (though not ex- 
ecutable) form and an associated program module 
dictionary. 


Off-Line. A generic reference to a device which may 
not be directly controlled by a computing system with 
which it is being used. 


On-Line. A generic reference to a device which can 
be directly controlled by a computing system to which 
it is electrically connected. 


On-Line Storage. Storage devices, and especially 
the storage media which they contain under the direct 
control of a computing system; not the off-line or 
shelf-storage of these media. 


One-Level Storage. A concept which treats all on- 
line storage, regardless of its physical characteris- 
tics, as having one level of appearance to a user; a 
technique which makes all on-line storage appear as 
main storage. 


Page. A set of 4096 consecutive bytes; applied to 
main storage, a set of 4096 consecutive bytes, the 
first byte of which is located at a storage address 
that is a multiple of 4096 (an address whose 12 low- 
order bits are 0). 


Page Boundary. A TSS/360 storage address that is a 
multiple of 4096; a System/360 address whose 12 low- 
order bits are 0. 


Page Table. A table containing the physical starting 
addresses of pages (for one segment) that are in pro- 
cessor storage. The page table argument is the page 
table starting address plus the virtual page address. 


Page Turning. See "Paging." 


Paging. The process of transmitting pages of infor- 
mation between main storage and auxiliary storage, 
especially when done for the purpose of assisting the 
allocation of a limited amount of main storage among 
a number of concurrently executing programs. 


Partitioning. The division of a multiprocessor con- 
figuration into two or more isolated subsystems. 


Physical Addresses. Addresses in processor storage. 


Privileged. (1) Privileged user: one who is entitled 

to execute certain system control commands from a 
terminal; (2) privileged module: a system module 

that is allowed to communicate with the TSS/360 super- 
visor; (3) privilege of access: an attribute of the level 
of allowable sharability of a shared data set (could be 
read-only access, read/write access, unlimited 
access, or no access). 


Problem Program. Any routine that performs proces- 
sing of the types for which a computing system is in- 
tended; including routines that solve problems, mon- 
itor and control industrial processes, sort and merge 
records, perform computation, process transactions 
against stored records, etc; generally interpreted to 
be any nonsystem program, 


Processing Programs. A generic description of pro- 
grams that have the primary function of processing in- 
formation and producing results, as compared with 
supervising and/or scheduling the flow of control 
through the system. 


Program, (N) A generic reference to collections of 
instructions and data produced for the solution of 
some well-defined problem; (V) to create and/or 
produce these collections. 
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Protection Key. An indicator associated with a task 
that appears in the program status word (PSW) when- 
ever the task is in control, and that is matched 
against the storage keys of all storage protection 
blocks that it is to use. 


Real Time. The actual time during which a physical 
process transpires, especially if that process is 
monitored or controlled by a computing system. 


Re-enterable. An attribute of a program that allows 
the program to be interrupted during execution, en- 
tered by another user, and, subsequently, re-entered 
at the point of interruption by the first user, and pro- 
duces the desired results for all users; a program 
with an intermediate state of execution that is totally 
restorable when it is re-entered after an interruption. 


Relocation, The movement of a program from one 
place in storage to another, including the modifica- 
tion to the program required therefrom. 


Response Time. The average time that a terminal 
user must wait to receive a response from the time 
sharing system; a measure of the rate at which the 
dialog between man and machine takes place. 


Routine. A sequence of machine instructions which 
carry out a well-defined function. 


Secondary Storage. The on-line storage of a compu- 
ting system that is not directly addressed by the reg- 
isters of a central processing unit. 


Segment, A logical grouping of data and procedure; 
on System/360 Model 67, an area of contiguous 
virtual storage equal to 256 pages, and on a 256-page 
boundary. 


Segment Table. A table that contains the physical 
starting addresses of page tables. The segment 
table argument is the segment number plus the 
starting address of the segment table. 


Storage Key. Indicators associated with storage pro- 
tection blocks which require that tasks have matching 
protection keys to use the blocks. 


Subroutine. A routine that performs a specific func- 
tion which is part of the overall objective of the rou- 
tine that uses it. 


Supervisor. The program modules, supplied by IBM, 


that control and monitor the usage of the time sharing 
system, 
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Supervisory Programs. A generic reference to the 
programs that have the primary function of scheduling, 
allocating, and controlling system resources, rather 
than processing data to produce results. 


Task, Any action, and all work undertaken as a result 
of such action, performed by TSS/360 under the direc- 
tion of a stream of commands from a system input 

unit, and associated with a particular user between the 
receipt of the LOGON and LOGOFF commands. Some 
background tasks are initiated for a user by the system, 
and are terminated by the completion of the operation 
to be performed. 


Throughput. A measure of the rate at which work 
can be performed by a computing system. 


Time Sharing. A method of using a computing system 
whereby a number of users can concurrently execute 
programs with which the users may interact during 
execution, and be generally assured some minimum 
amount of program execution per unit time. 


Time-Slice. The time during which each task executes 
before it is placed in a queue of tasks that are conten- 
ding for the system resources. 


TSS/360. The time-sharing operating system (a 
supervisory program) for use with the IBM System/ 
360 Model 67. 


Turnaround Time. The elapsed time between submis- 
sion of a task to a computing center and the return of 
results. 


User. Anyone who uses the services of a computing 
system. 


Virtual. Conceptual or appearing to be, rather than 
actually being. 


Virtual Address. An address generated by a program 
which references virtual or conceptual storage and 
must, therefore, be translated into a real storage 
address when it is to be used. 


Virtual Storage. A conceptual form of main storage 
which does not really exist, but is made to appear as 
if it exists through the use of hardware and program- 
ming. 


Wait Condition. As applied to tasks, the condition of 
a task that is dependent on events to enter the ready 
condition. 
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